jQuery数组处理方法汇总


Posted in Javascript onJune 20, 2011

$.each(array, [callback])遍历,很常用

var arr = ['javascript', 'php', 'java', 'c++', 'c#', 'perl', 'vb', 'html', 'css', 'objective-c']; 
$.each(arr, function(key, val) { 
// firebug console 
console.log('index in arr:' + key + ", corresponding value:" + val); 
// 如果想退出循环 
// return false; 
});

$.grep(array, callback, [invert])过滤,常用
var temp = []; 
temp = $.grep(arr, function(val, key) { 
if(val.indexOf('c') != -1) 
return true; 
// 如果[invert]参数不给或为false, $.grep只收集回调函数返回true的数组元素 
// 反之[invert]参数为true, $.grep收集回调函数返回false的数组元素 
}, false); 
console.dir(temp);

$.map(array, [callback])用的不是太多
//1.6之前的版本只支持数组 
temp = $.map(arr, function(val, key) { 
//返回null,返回的数组长度减1 
if(val === 'vb') return null; 
return val; 
}); 
console.dir(temp); 
//1.6开始支持json格式的object 
var obj = {key1: 'val1', key2: 'val2', key3: 'val3'}; 
temp = $.map(obj, function(val, key) { 
return val; 
}); 
console.dir(temp);

$.inArray(val, array)判断是否在指定数组中,常用
//返回元素在数组中的位置,0为起始位置,返回-1则未找到该元素 
console.log($.inArray('javascript', arr));

$.merge(first, second)合并两个数组,使用频率一般
var frontEnd = ['javascript', 'css', 'html'], 
backEnd = ['java', 'php', 'c++']; 
// 这种方式会修改第一个参数, 即frontEnd数组 
temp = $.merge(frontEnd, backEnd); 
console.dir(temp); 
console.dir(frontEnd); 
// 可以用下面的方式来避免对原数组的影响 
// $.merge($.merge([], frontEnd), backEnd);

$.unique(array)过滤数组中的重复元素,不常用
<DIV>blahblahblah....</DIV> 
<DIV></DIV> 
<DIV class=dup></DIV> 
<DIV class=dup></DIV> 
<DIV class=dup></DIV> 
<DIV></DIV> 
// $.unique只支持DOM元素数组,去除重复DOM元素,不支持其他类型数组(String或者Number) 
// 获得原始的DOM数组,而不是jQuery封装的 
var divs = $('div').get(); 
// 增加几个class为dup的div 
divs = divs.concat($('div.dup').get()); 
console.log("before unique:" + divs.length); 
divs = $.unique(divs); 
console.log("after unique:" + divs.length);

$.makeArray(obj)将类数组对象转成数组,不常用
//首先什么是类数组对象?jQuery官网上用divs = getElementsByTag('div')来做例子 
//这个divs有类似数组的一些方法比如length,通过[index]方式获取元素等 
//然后通过$.makeArray(divs)使它转为数组,就可以用数组的其他功能 
//比如reverse(), pop()等

$(dom).toArray()将jQuery集合恢复成DOM数组,不常用
 
//跟makeArray一样,相当的不常用,一般情况可以忽略
本文参考Mr.Think的blog,在此感谢分享
Javascript 相关文章推荐
原生js实现shift/ctrl/alt按键的获取
Apr 08 Javascript
在javascript中如何得到中英文混合字符串的长度
Jan 17 Javascript
JS控制一个DIV层在指定时间内消失的方法
Feb 17 Javascript
封装了jQuery的Ajax请求全局配置
Feb 05 Javascript
javascript制作网页图片上实现下雨效果
Feb 26 Javascript
jQuery结合CSS制作漂亮的select下拉菜单
May 03 Javascript
jQuery拖动元素并对元素进行重新排序
Dec 30 Javascript
记一次vue去除#问题处理经过小结
Jan 24 Javascript
javascript的惯性运动实现代码实例
Sep 07 Javascript
vue框架制作购物车小球动画效果实例代码
Sep 26 Javascript
JavaScript的console命令使用实例
Dec 03 Javascript
在vs code 中如何创建一个自己的 Vue 模板代码
Nov 10 Javascript
jQuery UI AutoComplete 使用说明
Jun 20 #Javascript
jQuery 源码分析笔记(3) Deferred机制
Jun 19 #Javascript
jQuery 源码分析笔记(7) Queue
Jun 19 #Javascript
jQuery 源码分析笔记(5) jQuery.support
Jun 19 #Javascript
jQuery调用WebService的实现代码
Jun 19 #Javascript
非常棒的10款jQuery 幻灯片插件
Jun 14 #Javascript
在jquery中处理带有命名空间的XML数据
Jun 13 #Javascript
You might like
PHP图片处理类 phpThumb参数用法介绍
2012/03/11 PHP
PHP的switch判断语句的“高级”用法详解
2014/10/01 PHP
PHP基于工厂模式实现的计算器实例
2015/07/16 PHP
分享5个非常有用的Laravel Blade指令
2018/05/30 PHP
浅谈laravel aliases别名的原理
2019/10/24 PHP
jQuery EasyUI API 中文文档 - ComboGrid 组合表格
2011/10/13 Javascript
JS获取当前日期和时间的简单实例
2013/11/19 Javascript
jQuery通过Ajax返回JSON数据
2015/04/28 Javascript
前端弹出对话框 js实现ajax交互
2016/09/09 Javascript
JavaScript排序算法动画演示效果的实现方法
2016/10/18 Javascript
bootstrap导航、选项卡实现代码
2016/12/28 Javascript
JavaScript实现替换字符串中最后一个字符的方法
2017/03/07 Javascript
JS实现侧边栏鼠标经过弹出框+缓冲效果
2017/03/29 Javascript
详解React native全局变量的使用(跨组件的通信)
2017/09/07 Javascript
详解html-webpack-plugin用法全解
2018/01/22 Javascript
jquery 获取索引值在一定范围的列表方法
2018/01/25 jQuery
浅谈VUE中演示v-for为什么要加key
2020/01/16 Javascript
JavaScript直接调用函数与call调用的区别实例分析
2020/05/22 Javascript
VsCode里的Vue模板的实现
2020/08/12 Javascript
Vue循环中多个input绑定指定v-model实例
2020/08/31 Javascript
python处理文本文件并生成指定格式的文件
2014/07/31 Python
Django中的“惰性翻译”方法的相关使用
2015/07/27 Python
Python 实现简单的电话本功能
2015/08/09 Python
Linux下通过python访问MySQL、Oracle、SQL Server数据库的方法
2016/04/23 Python
Python中文分词工具之结巴分词用法实例总结【经典案例】
2017/04/15 Python
Python中.join()和os.path.join()两个函数的用法详解
2018/06/11 Python
python实现推箱子游戏
2020/03/25 Python
wxPython电子表格功能wx.grid实例教程
2019/11/19 Python
HTML5 WebSocket实现点对点聊天的示例代码
2018/01/31 HTML / CSS
英国经典球衣网站:Classic Football Shirts
2017/05/20 全球购物
allbeauty美国:英国在线美容店
2019/03/11 全球购物
实习教师自我鉴定
2013/12/09 职场文书
今冬明春火灾防控工作方案
2014/05/29 职场文书
圆明园观后感
2015/06/03 职场文书
学生病假条范文
2015/08/17 职场文书
《包身工》教学反思
2016/02/23 职场文书