使用本文中的代码,我已成功添加querySelectorAll到documentIE7中.
但我需要在元素上使用它,而不是document像这样:
var containers = document.querySelectorAll('.container'); // Works
for (var i=0; i<=containers.length; i++) {
var container = containers[i];
container.querySelectorAll('a[data-type="people"]'); // Fails
// ...
}
Run Code Online (Sandbox Code Playgroud)
有没有办法querySelectorAll在IE7中添加元素而不仅仅是document?
我需要从JSON对象获取引用,代码如下:
var Tree = {
data: {
0: {
pk: 1,
},
1: {
pk: 2,
},
2: {
pk: 3,
children: {
0: {
pk: 11,
},
1: {
pk: 22,
},
2: {
pk: 33,
},
},
},
},
traverse: function(data, pk) {
for (i in data) {
// console.log(data[i]);
if(data[i].pk && data[i].pk == pk)
return data[i];
if (typeof(data[i].children) == 'object')
this.traverse(data[i].children, pk);
};
},
}
遍历顶级项目时,代码运行良好:
>>> Tree.traverse(Tree.data, 1);
Object {pk=1}
但是当得到子元素时坏了:
>>> Tree.traverse(Tree.data, 22); undefined
当你取消注释'// console.log(data [i]);'时,我很奇怪为什么会出现这种情况?你会看到该对象已被获取但未返回. …