解决for循环项问题

遇到问题如下:

 var children = document.querySelectorAll('.checkbutton-bg');
                for(var i in children){
                    children[i].style.backgroundImage = 'url('+atr.norbackground+')';
                }
报错:在children[i].style中无法获取第一层“div”的backgroundImage属性。

解决方案:

 var children = document.querySelectorAll('.checkbutton-bg');
                for(var i = 0; i != children.length; i++){
                    children[i].style.backgroundImage = 'url('+atr.norbackground+')';
                }

把for循环改成for(var i = 0; i != children.length;I++)就可以了。


原因分析:

从这个问题可以看出 for(vari=0;i!= children.length;i++)  与for(variinchildren)是有区别的。

在JS中,

测试代码:

 var children = document.querySelectorAll('.checkbutton-bg');
                var k = 1;
                console.log("children.length:"+children.length)
                for(var i in children){
                /*for(var i = 0; i != children.length; i++){*/
                    /*children[i].style.backgroundImage = 'url('+atr.norbackground+')';*/

                    console.log("K:"+ k++)
                    console.log(children[i])
                }

显示:

children.length:7
directive.js:84 K:1
directive.js:85 <div ng-click=​"toggle()​" ng-transclude class=​"checkbutton-bg" selectbackground=​"img/​other/​jinbikuang1.png" norbackground=​"img/​other/​jinbikuang.png" style=​"background-image:​ url("img/​other/​jinbikuang.png")​;​ background-size:​ 100% 100%;​ background-repeat:​ no-repeat;​">​…​</div>​
directive.js:84 K:2

directive.js:84 K:7
directive.js:85 <div ng-click=​"toggle()​" ng-transclude class=​"checkbutton-bg" selectbackground=​"img/​other/​jinbikuang1.png" norbackground=​"img/​other/​jinbikuang.png" style=​"background-image:​ url("img/​other/​jinbikuang.png")​;​ background-size:​ 100% 100%;​ background-repeat:​ no-repeat;​">​…​</div>​
directive.js:84 K:8
directive.js:85 7
directive.js:84 K:9





从上面可以看出,使用 for in 数组的长度应该是7,但是循环却一直循环到8,但是没有最后一个数组元素,进而导致报错。

这是由于在for in  中i表示项的索引,也就是 0、1、2、3……  ,二不是项。

这还不是致命的,看下面的示例:

Array. prototype.copy = function () { };
var arr = [1, 2];
for ( var index in arr)
{
     alert( index);
}

我们看到会弹出三个对话框,分别是:0、1、copy,也就是说除了项的数值索引 0、1,还多了一个 copy,而这个 copy 就是因为 Array.prototype.copy 扩展得到的。

所以说不要把 for (var index in items)  当作是 for (var i = 0; i < items.length; i++) 的一种简写,二者具有不同的意义。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值