下面的js代码为什么for循环后就停止执行了呢?

functionmyset(){varurl='./static/all/158老火锅(黄桷湾店).js';vara=getJs(url).body;vartm=$("#... function myset() {
var url='./static/all/158老火锅(黄桷湾店).js';
var a = getJs(url).body;
var tm=$("#t_item_name");
var line=[],cname=[],cid=[],kk=[];
line = a.split("\r\n");
for(var k in line){
if(line[k].indexOf("=") > 0 ){
cname=line[k].split(/\s*=\s*/);
cid.push(cname);
//alert(cname);//标记1-正常
};
//alert('无效的ID3');//标记2-正常
};
//tm.val("shshsss");
alert(cid); //标记3-没执行

return;
}
展开
 我来答
housq
推荐于2018-04-05 · 超过34用户采纳过TA的回答
知道答主
回答量:103
采纳率:0%
帮助的人:68.3万
展开全部
不知你的停止执行是什么意思,是执行了alert(cid); //标记3-没执行 这句吗,那么首先
对line 进行判断其值是否为空?
区别一:

for in是javascript 1.0
中发布的。

for each
in是作为E4X标准的一部分在javascript 1.6中发布的,而它不是ECMAScript标准的一部分。

这将意味着存在各种浏览器的兼容性问题。for each
in,对很多浏览器都不支持的。例如是不支持IE6,IE7,IE8等浏览器的。

区别二:

例: var 长方形= { 高:"15", 宽:"25" };

for (var i in 长方形){

alert( i + "," + 长方形[i]
);

}

结果依次是: 高,15 ; 宽,25 ;

for each (var i in 长方形){

alert( i + "," + 长方形[i]
);

}

结果依次是: 15, undefined ; 25, undefined;

两种遍历方法的变量i的值是不一样的,for each
in无法获得对象的属性名,只能获取到属性值。

最后总结一下使用建议:

(1)遍历普通数组,建议使用原生的遍历方法for,不要贪图方便,因为for in
和for each in均存在浏览器的兼容问题,不能保证它们对数组的遍历顺序(如果对顺序的不作要求的话,可以使用for in
,但本人不建议),有兴趣话,可以阅读的下一篇文章《for in
的浏览器兼容问题》。

(2)遍历对象,由于for没办法提供理想的遍历,因而只能选择其他方法。这里建议使用for in ,从上面讲解的区别,for in比for each
更具优势,for in能获取索引和属性值,而for each只能获取属性值,而且for each在很多低版本的浏览器是不支持。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式