不用JQuery,如何获取动态DOM,

index是参数,是for循环的序列号,:语法是vue语法,id用于echarts图表用,

在echarts中,类似这样初始化,echarts.init(document.getElementById('userLiveness'))

<div :id='"valueDistribution"+index' style="width: 180px;height:40px;"></div>

这是浏览器里渲染出来的dom

图片描述

在console里,是可以出来的

clipboard.png

但是在源码里是显示为null

clipboard.png

clipboard.png

阅读 4.8k
5 个回答

只要你元素id写对了,只要getElementById的时候你确定这个元素已经渲染出来了,就没问题。


你都getElementById了,干嘛还要加上#?


因为你代码执行到getElementById的时候,这个id元素还没有渲染出来,可以看一下vue组件的生命周期

你只是单纯想做节点查找的话、把数组拿过来、用变量拼接你的id

var index = 0;
document.getElementById("xxx"+index)

如果上面的index是for循环中的i、一样可以遍历到每个下标拼接的ID的节点

不知道你的ID到底是不是document.getElementById("valueDistribution0")、你的null的代码明显在document.getElementById("valueDistribution0"+index)相当于id是valueDistribution00了,拼接的话前面的0要去掉啊、这么粗心

setimeout循环查找

即使是动态加载的一样可以$("#id")找到。

而且也可以通过on的进行代理的方式绑定事件

document.getElementById没问题,不需要"#"

document.getElementById(xxx)

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题