Javascript动态生成HTML代码,添加的onclick属性在Chrome下面无效

没有用其它JS库代码我贴个主要的for(vari=0;i<4;i++){userli.appendChild(document.createElement("div"))... 没有用其它JS库

代码我贴个主要的
for (var i = 0; i < 4; i++) {
userli.appendChild(document.createElement("div"));
userli.childNodes[i].onclick = "divToEdit(this)";
}
document.getElementById("UserList").appendChild(userli);
opera下面可以有运行,但Chrome不行,也找不到onclick属性,alert出来竟然是null
展开
 我来答
槛外人网上人生
推荐于2016-04-08 · TA获得超过6254个赞
知道大有可为答主
回答量:1710
采纳率:0%
帮助的人:550万
展开全部
childNodes[i]
这句有错误,不同的浏览器对子节点的解析不同,
childNodes的下标的含义在IE和chrome中不同,chrome使用DOM规范,childNodes中会插入空白文本节点。一般可以通过node.getElementsByTagName()来回避这个问题。
解决方案:
chrome在遍历子节点时,在for循环里不妨加上:
if(childNodes[i].nodeName=="#text") {};
或者nodeType == 1。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式