jQuery中间each实施例的方法
2015-07-01 20:10
651 查看
$.each()和$(selector).each()很阶段似,但它是不一样的。
前者可用于遍历数组或json对象
后者被设计成遍历jQuery对象
第一个是$.each()对,通常这么用
当中arr也就是集合,也能够是json对象
而回调函数中的i则是数组的下标(在json中则是相应的key)
而v则是arr[i]的值(在json中则是相应的value)
以下来看一个简单的实例:
这样就完毕了对数组和json的遍历。
当然了,如此遍历用原生的js也是能够轻松做到的
比方遍历上面的json或是arr,仅仅须要:
看起来似乎还是js更简洁一些吧~性能上可能也要好一点
以下介绍$(selector).each()。这种方法在js中就不好找到替代品了。
当中$(selector)负责选中一组jQuery元素,而each函数负责遍历它
比方我们想对一组“li”改变其文字颜色
只是实际上,jQuery中存在隐式迭代的现象
每当我们调用选择器方法查找dom树里的元素时,事实上就是把找到的dom元素存入一个jQuery对象里的dom数组中,然后再把这个jQuery对象返回。
而所谓隐式迭代也就是当我们调用jQuery方法时(如 toggleClass(..))。jQuery方法会遍历内部 dom数组。并调用每一个dom元素的相应的dom属性或方法完毕操作。
全部click中的函数并不须要使用each,直接$("li").toggleClass('red')也能够
在$(seletor).each(..)中。this被绑定到了当前遍历的DOM对象,如需获得jQuery对象$(this)就能够了
值得需要注意的是,提前退场遍历时,也可以遍历,只需要return false在上面
前者可用于遍历数组或json对象
后者被设计成遍历jQuery对象
第一个是$.each()对,通常这么用
$.each(arr, function(i, v){ // do something })
当中arr也就是集合,也能够是json对象
而回调函数中的i则是数组的下标(在json中则是相应的key)
而v则是arr[i]的值(在json中则是相应的value)
以下来看一个简单的实例:
var json = {name:"zhu", age:10} var arr = ['a','b','c','d'] $.each(arr, function(i, v){ alert(i + ":" + v) }); $.each(json, function(k, v){ alert(k + ":" + v) });
这样就完毕了对数组和json的遍历。
当然了,如此遍历用原生的js也是能够轻松做到的
比方遍历上面的json或是arr,仅仅须要:
for(var k in json){ alert(k + ":" + arr[k]) }
看起来似乎还是js更简洁一些吧~性能上可能也要好一点
以下介绍$(selector).each()。这种方法在js中就不好找到替代品了。
当中$(selector)负责选中一组jQuery元素,而each函数负责遍历它
比方我们想对一组“li”改变其文字颜色
<style> .red{ color: red; } </style> <ul> <li>Dog</li> <li>Cat</li> <li>Mouse</li> </ul> <input type="button" id="btn"> <script> $("#btn").click(function() { $("li").each(function() { $(this).toggleClass('red'); }); }); </script>
只是实际上,jQuery中存在隐式迭代的现象
每当我们调用选择器方法查找dom树里的元素时,事实上就是把找到的dom元素存入一个jQuery对象里的dom数组中,然后再把这个jQuery对象返回。
而所谓隐式迭代也就是当我们调用jQuery方法时(如 toggleClass(..))。jQuery方法会遍历内部 dom数组。并调用每一个dom元素的相应的dom属性或方法完毕操作。
全部click中的函数并不须要使用each,直接$("li").toggleClass('red')也能够
在$(seletor).each(..)中。this被绑定到了当前遍历的DOM对象,如需获得jQuery对象$(this)就能够了
值得需要注意的是,提前退场遍历时,也可以遍历,只需要return false在上面
相关文章推荐
- JQuery使用的个人笔记
- jquery动态元素绑定事件
- 使用AmplifyJS和JQuery编写更好更优雅的javascript事件处理代码
- jquery获取当前时间
- jQuery获取父级元素、同级元素、子元素、过滤
- [jQuery] jQuery.extend 函数详解
- jQuery 效果 - fadeOut() 方法
- jquery跨域get请求问题解决
- JQuery中$.ajax()方法参数详解
- jQuery之$('#id')和$('#'+id)
- jquery分离方法split()
- jquery分离方法split()
- jquery validate 使用手册
- jQuery的.bind()、.live()和.delegate()之间区别
- jquery ajax GET POST 跨域请求实现
- jquery checkbox反复调用attr('checked', true/false)只有第一次生效
- jquery中复选框checked属性
- Jquery解析json数组字符串
- ajax json jQuery提示parsererror错误解决办法
- jQuery 中获取调用Tab的当前页面