JQuery $.each与$().each区别, for in 与 for of 区别

本文深入探讨了jQuery中$.each()函数与().each()的区别,分别用于遍历数组、对象和DOM元素,同时对比了for...in与for...of循环在不同场景下的应用,为前端开发者提供了实用的代码优化策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. .each()]与.each()]与.each()]().each()区别

$.each用于遍历数组、对象、数组对象, 代码形式(arr,function(index,value))或(obj, function(key, value) {})
().each用于遍历dom,代码形式如().each用于遍历dom, 代码形式如().eachdom,(‘li’).each(function() { alert(this.xxx) })
demo:

 <script>
        $(function () {
            // 对象
            var a = { "name": 'Lucky', age: 12, sayName: function () { alert(this.name) } };
            $.each(a, function (key, value) {
                console.log(key + "===" + value);
            });//name===Lucky   age===12  sayName===function () { alert(this.name) }

            // 数组
            var b = ["Day", 2, 3];
            $.each(b, function (f, e) {
                console.log(f + ":" + e);
            });//0:Day 1:2   2:3
           

            // 对象数组
            var c = [];
            c.push(a);
            $.each(c, function (index, value) {
                console.log(index + "=" + value.name);
            });//0=Lucky   
          

            // dom, 也可这么写function(index, e) {$(e).text()}
            $('p').each(function () {
                console.log($(this).text());
            });

        });

    </script>
    <p>如果您点击我,我会消失。</p>
    <p>点击我,我会消失。</p>
    <p>也要点击我哦。</p>
  1. for in 与 for of区别
    for in能遍历数组与对象的可枚举属性,但是不仅遍历对象内部,而且会遍历原型链(若只遍历对象内部,配合obj.hasOwnProperty(【属性】))
    for of,(ES6增加)能遍历数组,但是不能遍历对象(ES6遍历对象内部可用Symbol.iterator)
    demo:
var a = {"name": 'Lucky', age: 12, sayName: function() { alert(this.name)}};
    var b = ["Day",2,3];
    var ele; 

    for (ele in a) {
         console.log(ele +':' +  a[ele]); //输出属性名称及属性值
    }
   for (ele in b) {
         console.log(ele + ':' + b[ele]);//输出属性名称及属性值
    }


   for (ele of b) {
         console.log(ele);  //输出数组属性值
    }
    /*报错:VM3258 v.asp:19 Uncaught TypeError: a[Symbol.iterator] is not a function(…)*/
    for (ele of a) {
         console.log(ele +':' +  a[ele]);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

百事可爱-墨宝

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值