jQuery.each使用详解


Posted in Javascript onJuly 07, 2015

jQuery.each方法是jQuery的核心工具方法之一,通用例遍方法,可用于例遍对象和数组。不同于例遍 jQuery 对象的 $().each() 方法,此方法可用于例遍任何对象。通常需要两个参数

object:需要例遍的对象或数组。

callback:每个成员/元素执行的回调函数。

回调函数拥有两个参数:第一个为对象的成员或数组的索引,第二个为对应变量或内容。如果需要退出 each 循环可使回调函数返回 false,其它返回值将被忽略。

例遍数组,同时使用元素索引和内容。举例如下:

//例遍对象,同时使用成员名称和变量内容。

$.each( [0,1,2], function(i, n){
 alert( "Item #" + i + ": " + n );
});
//例遍对象,同时使用成员名称和变量内容。

$.each( { name: "John", lang: "JS" }, function(i, n){
 alert( "Name: " + i + ", Value: " + n );
});

当然也可以直接使用实例调用

$( 'div' ).each( function(i,n){
    return i+n.text;
  } )

其实在源码中实例(原型)方法也是调用的静态方法,所以分析each方法只需要分析其静态方法即可,实例调用只不过是静态方法使用中的一个特例罢了。

// Execute a callback for every element in the matched set.
  // (You can seed the arguments with an array of args, but this is
  // only used internally.)
  each: function( callback, args ) {
    return jQuery.each( this, callback, args );
  },

在原型方法中直接把this对象当作待遍历的对象传入,下面是静态方法的源码

// args is for internal usage only
  each: function( object, callback, args ) {
    var name, i = 0,
      length = object.length,
      isObj = length === undefined || jQuery.isFunction( object );
    if ( args ) {
      if ( isObj ) {
        for ( name in object ) {
          if ( callback.apply( object[ name ], args ) === false ) {
            break;
          }
        }
      } else {
        for ( ; i < length; ) {
          if ( callback.apply( object[ i++ ], args ) === false ) {
            break;
          }
        }
      }

    // A special, fast, case for the most common use of each
    } else {
      if ( isObj ) {
        for ( name in object ) {
          if ( callback.call( object[ name ], name, object[ name ] ) === false ) {
            break;
          }
        }
      } else {
        for ( ; i < length; ) {
          if ( callback.call( object[ i ], i, object[ i++ ] ) === false ) {
            break;
          }
        }
      }
    }

    return object;
  },

东西也不是很多,首先接受3个参数,这个时候就要注意了在我们经常使用的手册中一般是写的两个参数的我们一般使用也是使用两个参数,但是其实在源码中是有3个参数可以接受的,其中第三个参数是一个数组,会作为回调函数的参数传入。

首先声明几个变量,i、name和length是为循环做准备的,isObj是为了区分待便利的参数是数组还是对象,通过判断该参数如果是函数或者length属性不存在来判断是对象,其他的就按数组或者类数组来处理。

isObj = length === undefined || jQuery.isFunction( object );
这一句写的很精简利用运算符的优先顺序先执行===

其实这样的判断并不是很精准只是一个大致的区分,比如:

var obj={length:'a'};
 var isObj= obj.length=== undefined || jQuery.isFunction( obj );
 alert(isObj); //false

然后就是根据是否添加第三个参数进行区分,先看下没有添加的情况也就是

} else {
      if ( isObj ) {
        for ( name in object ) {
          if ( callback.call( object[ name ], name, object[ name ] ) === false ) {
            break;
          }
        }
      } else {
        for ( ; i < length; ) {
          if ( callback.call( object[ i ], i, object[ i++ ] ) === false ) {
            break;
          }
        }
      }
    }

根据isObj变量“区分”数组和对象,对于数组使用for循环,对于对象采用for...in循环,每循环一此就会执行一次回调函数并把当前循环的数组或者对象键和值传进去,这里使用的call方法,第一个参数是函数的“this”也就是把当前循环的值作为this后面两个是键和值或者是指针和值,所以我们使用循环中使用回调函数的第二个参数跟使用this是一样的。比如:

//刚才的例子
 $( 'div' ).each( function(i,n){
    return i+n.text;
  } )
//等价于
 $( 'div' ).each( function(i,n){
    return i+this.text;
  } )

  对于添加了第三个参数的情况而言就是改变了回调函数的传值方式,使用的是apply方法来传递参数,this指向的依然是当前值只不过把args也就是第三个参数数组传递进去,这个数组有多少参数那么回调函数就有多少参数可以用,这里需要注意的是第三个一定是js原声数组形式不能是类数组或者jQuery对象否则会报错因为apply方法不支持。如果回调函数返回false那么将跳过循环比如我们可以只处理奇数下标数组是可以判断是偶数项时在回调函数中执行return false即可

return object;

最后返回原对象或者数组等

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
解析window.open的使用方法总结
Jun 19 Javascript
jQuery带箭头提示框tooltips插件集锦
Nov 17 Javascript
Javascript数组Array方法解读
Mar 13 Javascript
分享JS代码实现鼠标放在输入框上输入框和图片同时更换样式
Sep 01 Javascript
js获取时间函数及扩展函数的方法
Oct 30 Javascript
基于jQuery实现Tabs选项卡自定义插件
Nov 21 Javascript
Vue.js第二天学习笔记(vue-router)
Dec 01 Javascript
jQuery实现移动端Tab选项卡效果
Mar 15 Javascript
深入理解Node.js中通用基础设计模式
Sep 19 Javascript
3分钟读懂移动端rem使用方法(推荐)
May 06 Javascript
微信小程序:数据存储、传值、取值详解
May 07 Javascript
详解Vue的七种传值方式
Feb 08 Vue.js
JavaScript中字符串拼接的基本方法
Jul 07 #Javascript
简单介绍JavaScript中字符串创建的基本方法
Jul 07 #Javascript
浅谈JavaScript中运算符的优先级
Jul 07 #Javascript
浏览器中url存储的JavaScript实现
Jul 07 #Javascript
浅谈JavaScript中的作用域和闭包问题
Jul 07 #Javascript
深入分析下javascript中的[]()+!
Jul 07 #Javascript
javascript实现的多个层切换效果通用函数实例
Jul 06 #Javascript
You might like
PHP面向对象三大特点学习(充分理解抽象、封装、继承、多态)
2012/05/07 PHP
Drupal7连接多个数据库及常见问题解决
2014/03/02 PHP
php操作memcache缓存方法分享
2015/06/03 PHP
学习php设计模式 php实现单例模式(singleton)
2015/12/07 PHP
php数组指针操作详解
2017/02/14 PHP
PHP使用两个栈实现队列功能的方法
2018/01/15 PHP
Laravel5.7 数据库操作迁移的实现方法
2019/04/12 PHP
php设计模式之原型模式分析【星际争霸游戏案例】
2020/03/23 PHP
客户端脚本中常常出现的一些问题和调试技巧
2007/01/09 Javascript
Javascript面象对象成员、共享成员变量实验
2010/11/19 Javascript
javascript读写XML实现广告轮换(兼容IE、FF)
2013/08/09 Javascript
JQuery操作iframe父页面与子页面的元素与方法(实例讲解)
2013/11/20 Javascript
JavaScript设计模式之单件模式介绍
2014/12/28 Javascript
详解JavaScript for循环中发送AJAX请求问题
2020/06/23 Javascript
深入理解JS中的Function.prototype.bind()方法
2016/10/11 Javascript
seajs模块之间依赖的加载以及模块的执行
2016/10/21 Javascript
深入理解jquery中extend的实现
2016/12/22 Javascript
基于canvas的二维码邀请函生成插件
2017/02/14 Javascript
layui实现动态和静态分页
2018/04/28 Javascript
jQuery AJAX 方法success()后台传来的4种数据详解
2018/08/08 jQuery
JS使用Date对象实时显示当前系统时间简单示例
2018/08/23 Javascript
在Vue中使用Viser说明(基于AntV-G2可视化引擎)
2020/10/28 Javascript
Vue在H5 项目中使用融云进行实时个人单聊通讯
2020/12/14 Vue.js
python 匹配url中是否存在IP地址的方法
2018/06/04 Python
python名片管理系统开发
2020/06/18 Python
树莓派4B安装Tensorflow的方法步骤
2020/07/16 Python
Python paramiko使用方法代码汇总
2020/11/20 Python
CSS3使用多列制作瀑布流
2016/05/10 HTML / CSS
CSS3制作酷炫的条纹背景
2017/11/09 HTML / CSS
html5仿支付宝密码框的实现代码
2017/09/06 HTML / CSS
后勤园长自我鉴定
2013/10/17 职场文书
教育专业个人求职信
2013/12/02 职场文书
小学数学国培感言
2014/03/10 职场文书
2016学习全国教书育人楷模先进事迹心得体会
2016/01/21 职场文书
纯CSS3实现div按照顺序出入效果
2021/07/15 HTML / CSS
SpringBoot详解自定义Stater的应用
2022/07/15 Java/Android