jQuery源码分析之jQuery中的循环技巧详解


Posted in Javascript onSeptember 06, 2014

jQuery的源码中有很多值得学习借鉴的技巧,本文即收集了jQuery中出现的各种遍历技巧和场景。具体分析如下:

// 简单的for-in(事件) 
for ( type in events ) { 
 
} 
// 缓存length属性,避免每次都去查找length属性,稍微提升遍历速度 
// 但是如果遍历HTMLCollection时,性能提升非常明显,因为每次访问HTMLCollection的属性,HTMLCollection都会内部匹配一次所有的节点 
for ( var j = 0, l = handlers.length; j < l; j++ ) { 
 
} 
// 不比较下标,直接判断元素是否为true(强制类型转换) 
var elem; 
for ( var i = 0; elems[i]; i++ ) { 
  elem = elems[i]; 
  // ... 
} 
// 遍历动态数组(事件),不能缓存length属性,j++之前先执行j--,保证不会因为数组下标的错误导致某些数组元素遍历不到 
for ( j = 0; j < eventType.length; j++ ) { 
eventType.splice( j--, 1 ); 
} 
for ( var i = 1; i < results.length; i++ ) { 
  if ( results[i] === results[ i - 1 ] ) { 
    results.splice( i--, 1 ); 
  } 
} 
// 迭代过程中尽可能减少遍历次数(事件),如果你能知道从哪里开始遍历的话,这里是pos 
for ( j = pos || 0; j < eventType.length; j++ ) { 
 
} 
//倒序遍历(事件),减少了几个字符:循环条件判断,合并i自减和i取值,倒序遍历会有浏览器优化,稍微提升遍历速度 
for ( var i = this.props.length, prop; i; ) { 
  prop = this.props[ --i ]; 
  event[ prop ] = originalEvent[ prop ]; 
} 
// 倒序遍历,中规中矩,倒序会有浏览器优化,稍微提升遍历速度 
for ( j = tbody.length - 1; j >= 0 ; --j ) { 
  if ( jQuery.nodeName( tbody[ j ], "tbody" ) && !tbody[ j ].childNodes.length ) { 
    tbody[ j ].parentNode.removeChild( tbody[ j ] ); 
  } 
} 
//不判断下标,直接判断元素(选择器) 
for ( i = 0; checkSet[i] != null; i++ ) { 
  if ( checkSet[i] && (checkSet[i] === true || checkSet[i].nodeType === 1 && Sizzle.contains(context, checkSet[i])) ) { 
    results.push( set[i] ); 
  } 
} 
for ( ; array[i]; i++ ) { 
  ret.push( array[i] ); 
} 
// 不判断下标,取出元素然后判断元素(选择器) 
for ( var i = 0; (item = curLoop[i]) != null; i++ ) { 
 
} 
// 遍历DOM子元素 
for ( node = parent.firstChild; node; node = node.nextSibling ) { 
  if ( node.nodeType === 1 ) { 
    node.nodeIndex = ++count; 
  } 
} 
// 动态遍历DOM子元素(DOM遍历),dir参数表示元素的方向属性,如parentNode、nextSibling、previousSibling、lastChild和firstChild 
for ( ; cur; cur = cur[dir] ) { 
  if ( cur.nodeType === 1 && ++num === result ) { 
    break; 
  } 
} 
// while检查下标i 
var i = promiseMethods.length; 
while( i-- ) { 
  obj[ promiseMethods[i] ] = deferred[ promiseMethods[i] ]; 
} 
// while检查元素 
while( (type = types[ i++ ]) ) { 
 
} 
// while遍历动态数组(AJAX),总是获取第一个元素,检查是否与特殊值相等,如果相等就从数组头部移除,直到遇到不相等的元素或数组为空 
while( dataTypes[ 0 ] === "*" ) { 
  dataTypes.shift(); 
  if ( ct === undefined ) { 
    ct = s.mimeType || jqXHR.getResponseHeader( "content-type" ); 
  } 
} 
// while遍历动态数组(异步队列),总是获取第一个元素,直到数组为空,或遇到值为undefined的元素 
while( callbacks[ 0 ] ) { 
  callbacks.shift().apply( context, args ); 
} 
// while反复调用RegExp.exec(AJAX),能够否反复调是exec比re.test、String.match更加强大的原因,每次调用都将lastIndex属性设置到紧接着匹配字符串的字符位置 
while( ( match = rheaders.exec( responseHeadersString ) ) ) { 
  responseHeaders[ match[1].toLowerCase() ] = match[ 2 ]; // 将响应头以key-value的方式存在responseHeaders中 
}

希望本文所述对大家jQuery的WEB程序设计有所帮助。

Javascript 相关文章推荐
用javascript获得地址栏参数的两种方法
Nov 08 Javascript
简约JS日历控件 实例代码
Jul 12 Javascript
在JavaScript中操作时间之getYear()方法的使用教程
Jun 11 Javascript
Vue.js系列之vue-router(上)(3)
Jan 03 Javascript
js实现导航吸顶效果
Feb 24 Javascript
微信小程序新增的拖动组件movable-view使用教程
May 20 Javascript
jQuery修改DOM结构_动力节点Java学院整理
Jul 05 jQuery
vue绑定设置属性的多种方式(5)
Aug 16 Javascript
详解webpack进阶之loader篇
Aug 23 Javascript
vue 翻页组件vue-flip-page效果
Feb 05 Javascript
JS Generator 函数的含义与用法实例总结
Apr 08 Javascript
微信小程序轮播图swiper代码详解
Dec 01 Javascript
10分钟学会写Jquery插件实例教程
Sep 06 #Javascript
页面加载完后自动执行一个方法的js代码
Sep 06 #Javascript
jquery mobile页面跳转后样式丢失js失效的解决方法
Sep 06 #Javascript
禁止iframe脚本弹出的窗口覆盖了父窗口的方法
Sep 06 #Javascript
js和jquery中循环的退出和继续学习记录
Sep 06 #Javascript
jquery实现html页面 div 假分页有原理有代码
Sep 06 #Javascript
JavaScript及jquey实现多个数组的合并操作
Sep 06 #Javascript
You might like
解密ThinkPHP3.1.2版本之独立分组功能应用
2014/06/19 PHP
php数组操作之键名比较与差集、交集赋值的方法
2014/11/10 PHP
PHP实现生成模糊图片的方法示例
2017/12/21 PHP
PHP使用Session实现上传进度功能详解
2019/08/06 PHP
javascript应用:Iframe自适应其加载的内容高度
2007/04/10 Javascript
基于jquery的超简单上下翻
2010/04/20 Javascript
THREE.JS入门教程(1)THREE.JS使用前了解
2013/01/24 Javascript
在javascript中关于节点内容加强
2013/04/11 Javascript
js中的scroll和offset 使用比较的实例与分析
2013/09/29 Javascript
Get中文乱码IE浏览器Get中文乱码解决方案
2013/12/26 Javascript
BootStrap Tooltip插件源码解析
2016/12/27 Javascript
jQuery插件echarts实现的多折线图效果示例【附demo源码下载】
2017/03/04 Javascript
关于vue-router路径计算问题
2017/05/10 Javascript
微信小程序表单验证错误提示效果
2017/05/19 Javascript
详解jQuery同步Ajax带来的UI线程阻塞问题及解决办法
2017/08/09 jQuery
轻松玩转BootstrapTable(后端使用SpringMVC+Hibernate)
2017/09/06 Javascript
vue实现长图垂直居上 vue实现短图垂直居中
2017/10/18 Javascript
详解解决Vue相同路由参数不同不会刷新的问题
2018/10/12 Javascript
python 中的列表解析和生成表达式
2011/03/10 Python
Python中方法链的使用方法
2016/02/23 Python
python去掉行尾的换行符方法
2017/01/04 Python
python 不以科学计数法输出的方法
2018/07/16 Python
Python+threading模块对单个接口进行并发测试
2019/06/25 Python
Windows平台Python编程必会模块之pywin32介绍
2019/10/01 Python
ubuntu 18.04 安装opencv3.4.5的教程(图解)
2019/11/04 Python
CentOS7下安装python3.6.8的教程详解
2020/01/03 Python
Python 列表推导式需要注意的地方
2020/10/23 Python
新西兰优惠网站:Treat Me
2019/07/04 全球购物
新闻记者实习自我鉴定
2013/09/19 职场文书
酒店员工检讨书
2014/02/18 职场文书
国际贸易毕业生自荐书
2014/06/22 职场文书
财务务虚会发言材料
2014/10/20 职场文书
护理医院见习报告
2014/11/03 职场文书
学校施工安全责任书
2015/01/29 职场文书
导游经典开场白——导游词
2019/04/17 职场文书
Golang 语言控制并发 Goroutine的方法
2021/06/30 Golang