深入理解$.each和$(selector).each
$.each该方法用于遍历任何集合,包括数组和对象
$(selector).each:该方法用于遍历Jquery对象
语法$.each(obj,callback,args)
①遍历数组
var arry = ["a","b","c","d",…];
$.each(arry,function(index,value){…})
回调函数中index 代表数组的索引 ,value 代表数组中的值
②遍历Json对象
var json = {key1:value1, key2:value2, key3:value3}
$.each(json, function(key,value){…})
回调函数中key 代表json对象中的key, value 代表json对象中的value
③遍历Jquery对象
var doms = $("div");//Jquery对象本身是一个集合,通过索引的方式可以将Jquery对象转换为Dom对象
$.each(doms, function(index,value){..})
回调函数中index 代表Jquery对象中的索引, value 代表Jquery对象中的dom对象,也可以通过this得到同样的dom对象
对于③还有一种写法就是 $("div").each(function(index,value){…})
对于$.each方法可以通过在回调函数中return false退出循环,如果return true 则相当于for循环中的continue
疑问为什么$().each回调函数中的this不是Jquery对象 而是Dom对象
由于$().each方法的本质是通过调用$.each实现的,通过分析$.each源码可知,我们可以看到callback.apply(object[i++],args)这段代码
对于$().each传进去的object正是Jquery对象,而object[i++]将Jquery对象转换为dom对象,再根据apply方法劫持对象的特性,那么回调函数中的this就被改变成了dom对象
我们经常在Jquery插件中看到这种写法,通过上面的分析,我想就应该懂了
$.fn.test = function(option){ return this.each(function(){//这个this是Jquery对象 alert(this);//而这个this却是Dom对象 }) }
以上这篇深入理解$.each和$(selector).each就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程