Jquery真的不难~第五回 JQ中的遍历(遍历中的性能知识点)

回到目录

上一回主要说的是JQ中的几个主要的事件,文章的最后还介绍了匿名函数的使用,恩,今天主要来看一下JQ中的遍历,就是在JQ中进行循环操作以及在遍历时要注意的地方。

前言

要讲遍历就要说数组,你不可以对一个单独的变量进行遍历吧,呵呵,数组是一些各种类型变量的集合,在JS中一个数组,你完全可以把数字与字符混合在一起,这是合法的。

JS中的数组

数组的定义

  var arr = [1, 2, 3, 4, "one", "two", "three", "four"]; //一维数组
  var props = [["拳头", "刀", "枪"], ["boxing", "knife  ", "gun"]]; //二维数组

调用

   console.log(arr[0]);
   console.log(props[0][0]);

JS对数组的遍历

        for (var i in arr) {//可能性不高
            console.log(arr[i]);
        }

        for (var i = 0; i < arr.length; i++) { //性能差的
            console.log(arr[i]);
        }

        for (var i = 0, max = arr.length; i < max; i++) {//性能好的
            console.log(arr[i]);
        }

JQ中的集合

对于在JQ中用选择器选择对象后,它将返回一个JQ对象,这个对象可以是一个元素,也可能是一个集合,一般地,我们用$("#ID")返回的是一个对象,因为ID在页面中正常情况下是唯一的,而使用$(".className"),Find()等返回一般是个集合,或者说是个JQ对象数组,看代码:

 <script>  
  $(function () {
            //返回JQ对象集合
            var jqArr = $("#menu_title").find("dt");
            console.log("menu_title下的dt元素数量为:" + jqArr.size());
            console.log("menu_title下的第一个dt的内容为:" + jqArr[0].html()); //会出错,因为jqArr[0]已经不是JQ对象了
            console.log("menu_title下的第一个dt的内容为:" + $(jqArr[0]).html());//正确,因为加上$()后,它将被转化为JQ对象
        });
 </script>
  <dl id="menu_title">
        <dt>人</dt>
        <dd>
            一种高级动物</dd>
        <dt>狗</dt>
        <dd>
            人类的朋友</dd>
        <dt>猫</dt>
        <dd>
            猫科动物的祖先</dd>
    </dl>

结果为:

JQ对集合的遍历

         jqArr.each(function (i, o) {
                console.log("第" + i + "号元素的内容是:" + $(o).html());
            });

结果为:

从结果中我们可以看到,$.each(function(i,o){})方法中的i表示JQ数组的索引值,而o表示JQ数组的值,而o加上$()变成JQ对象之后,使用html()这个方法可以输出o这个对象里的内容;从图中还可以看到JQ产生的数组的索引也是从0开始的。

总结

JS与JQ数组(集合)的相关知识就介绍到这里了,对于它们的使用还需要各位在实现工作中去体现,另外,在写代码时,多站在系统层次上去感觉一下,去用心去体会,你可能会有另外的收获!

回到目录

 

posted @ 2013-01-17 13:34  张占岭  阅读(7135)  评论(1编辑  收藏  举报