jquery数组封装使用方法分享(jquery数组遍历)


Posted in Javascript onMarch 25, 2014

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

不同于例遍 jQuery 对象的 $.each() 方法,此方法可用于例遍任何对象(不仅仅是数组哦~). 回调函数拥有两个参数:第一个为对象的成员或数组的索引, 第二个为对应变量或内容. 如果需要退出 each 循环可使回调函数返回 false, 其它返回值将被忽略.

each遍历,相信都不陌生,在平常的事件处理中,是for循环的变体,但比for循环强大.在数组中,它可以轻松的攻取数组索引及对应的值.例:

使用方法如下:

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;
});

再来个测试程序:
[/code]
 var fruit = ['苹果','香蕉','橙子','哈密瓜','芒果'];
 //用原生getElementsByTagName获取h2元素的对象集合
 var h2obj=document.getElementsByTagName('h2');

 //$.each()遍历数组
 $('input#js_each').click(function(){
  $.each(fruit,function(key,val){
   //回调函数有两个参数,第一个是元素索引,第二个为当前值
   alert('fruit数组中,索引:'+key+'对应的值为:'+val);
  });
 });

[/code]
相对于原生的for..in,each更强壮一点. for..in也可以遍历数组,并返回对应索引,但值是需要通过arrName[key]来获取;

$.grep(array, callback, [invert])过滤

使用过滤函数过滤数组元素.此函数至少传递两个参数(第三个参数为true或false,对过滤函数返回值取反,个人觉得用处不大): 待过滤数组和过滤函数. 过滤函数必须返回 true 以保留元素或 false 以删除元素. 另外,过滤函数还可以是可设置为一个字条串(个人不推荐,欲了解自行查阅);

v[code]ar 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);

再来个测试程序:

 //$.grep()过滤数组
 $('input#js_grep').click(function(){
  $.grep(fruit,function(val,key){
   //过滤函数有两个参数,第一个为当前元素,第二个为元素索引
   if(val=='芒果'){
    alert('数组值为 芒果 的下标是: '+key);
   }
  });  var _moziGt1=$.grep(fruit,function(val,key){
   return key>1;
  });
  alert('fruit数组中索引值大于1的元素为: '+_moziGt1);
  var _moziLt1=$.grep(fruit,function(val,key){
   return key>1;
  },true);
  //此处传入了第三个可靠参数,对过滤函数中的返回值取反
  alert('fruit数组中索引值小于等于1的元素为: '+_moziLt1);
 });

$.map(array,[callback])按给定条件转换数组

作为参数的转换函数会为每个数组元素调用, 而且会给这个转换函数传递一个表示被转换的元素作为参数. 转换函数可以返回转换后的值、null(删除数组中的项目)或一个包含值的数组, 并扩展至原始数组中.这个是个很强大的方法,但并不常用. 它可以根据特定条件,更新数组元素值,或根据原值扩展一个新的副本元素.

//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);

再来个测试程序:

 //$.map()按给定条件转换数组
 $('input#js_map').click(function(){
  var _mapArrA=$.map(fruit,function(val){
   return val+'[新加]';
  });
  var _mapArrB=$.map(fruit,function(val){
   return val=='苹果' ? '[只给苹果加]'+val : val;
  });
  var _mapArrC=$.map(fruit,function(val){
   //为数组元素扩展一个新元素
   return [val,(val+'[扩展]')];
  });
  alert('在每个元素后面加\'[新加]\'字符后的数组为: '+ _mapArrA);
  alert('只给元素 苹果 添加字符后的数组为: '+ _mapArrB);
  alert('为原数组中每个元素,扩展一个添加字符\'[新加]\'的元素,返回的数组为 '+_mapArrC);
 });

$.inArray(val,array)判断值是否存在于数组中

确定第一个参数在数组中的位置, 从0开始计数(如果没有找到则返回 -1 ).记得indexOf()方法了吗? indexOf()返回字符串的首次出现位置,而$.inArray()返回的是传入参数在数组中的位置,同样的,如果找到的,返回的是一个大于或等于0的值,若未找到则返回-1.现在, 知道怎么用了吧. 有了它, 判断某个值是否存在于数组中,就变得轻而易举了.

//返回元素在数组中的位置,0为起始位置,返回-1则未找到该元素
console.log($.inArray('javascript', arr));

测试程序:
[code]
 //$.inArray判断值是否在数组中,不存在返回-1,存在则返回对应索引值
 $('input#js_inarray').click(function(){
  var _exist=$.inArray('芒果',fruit);
  var _inexistence=$.inArray('榴莲',fruit)
  if(_exist>=0){
   alert('芒果 存在于数组fruit中,其在数组中索引值是: '+_exist);
  }
  if(_inexistence< 0){
   alert('榴莲 不存在于数组fruit中!,返回值为: '+_inexistence+'!');
  }
 });

$.merge(first,second)合并两个数组

返回的结果会修改第一个数组的内容——第一个数组的元素后面跟着第二个数组的元素. 这个方法是用jQuery的方法替代原生concat()方法, 但功能并没有concat()强大, concat()可以同时合并多个数组.

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

测试程序

 //$.merge()合并两个数组
 $('input#js_merge').click(function(){
  //原生concat()可能比它还简洁点
  fruitNew=$.merge(fruit,['水蜜桃','火龙果','西瓜','杨桃','荔枝','龙眼'])
  alert('合并后新数组长度为: '+fruitNew.length+'. 其值为: '+fruitNew);
 });

$.unique(array)过滤数组中重复元素

删除数组中重复元素. 只处理删除DOM元素数组,而不能处理字符串或者数字数组.第一次看到这个方法,觉得这是个很便捷的方法, 可以过滤重复, 哈, 多完美, 但仔细一看, 仅限处理DOM元素. 功能8折了.所以, 我给它定义成了一个不常用的元素, 至少, 我用jQuery以来没用到过它.

<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);

测试程序:

 //$.unique()过滤数组中重复元素(仅限DOM元素数组)
 $('input#js_unique').click(function(){
  var _h2Arr=$.makeArray(h2obj);
  //将数组_h2Arr重复一次
  _h2Arr=$.merge(_h2Arr,_h2Arr);
  var _curLen=_h2Arr.length;
  _h2Arr=$.unique(_h2Arr);
  var _newLen=_h2Arr.length;
  alert('数组_h2Arr原长度值为: '+_curLen+' ,过滤后为: '+_newLen+' .共过滤 '+(_curLen-_newLen)+'个重复元素');
 });

$.makeArray(obj) 将类数组对象转换为数组

将类数组对象转换为数组对象, 类数组对象有 length 属性,其成员索引为0至 length-1.这是个多余的方法, 无所不能的$本来就包含了这个功能. jQuery官网上解释的非常模糊. 其实, 它就是将某个类数组对象(比如用getElementsByTagName获取的元素对象集合)转换成数组对象.

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

 //$.makeArr()类数组转换
 $('input#js_makearray').click(function(){
  var _makeArr=$.makeArray(h2obj);
  alert('h2元素对象集合的数据类型转换为: '+_makeArr.constructor.name);
 });

$(dom).toArray()将所有DOM元素恢复成数组

把jQuery集合中所有DOM元素恢复成一个数组;并不常用的方法, 个人甚至觉得它和$.makeArray一样多余.

 //$(dom).toArray()将所有DOM元素恢复成数组
 $('input#js_toarray').click(function(){
  var _toArr=$('h2').toArray();
  alert('h2元素集合恢复后的数据类型是: '+_toArr.constructor.name);
Javascript 相关文章推荐
Javascript 面向对象 对象(Object)
May 13 Javascript
基于jQuery的Spin Button自定义文本框数值自增或自减
Jul 17 Javascript
深入理解Javascript闭包 新手版
Dec 28 Javascript
Ajax执行顺序流程及回调问题分析
Dec 10 Javascript
Blocksit插件实现瀑布流数据无限( 异步)加载
Jun 20 Javascript
简介JavaScript中的push()方法的使用
Jun 09 Javascript
javascript实现的字符串转换成数组操作示例
Jun 13 Javascript
vuex vue简单使用知识点总结
Aug 29 Javascript
详解Vue 项目中的几个实用组件(ts)
Oct 29 Javascript
vue进入页面时不在顶部,检测滚动返回顶部按钮问题及解决方法
Oct 30 Javascript
js实现3D粒子酷炫动态旋转特效
Sep 13 Javascript
Vue 防止短时间内连续点击后多次触发请求的操作
Nov 11 Javascript
jquery选择器原理介绍($()使用方法)
Mar 25 #Javascript
Jquery插件编写简明教程
Mar 25 #Javascript
jquery自动填充勾选框即把勾选框打上true
Mar 24 #Javascript
jquery默认校验规则整理
Mar 24 #Javascript
Javascript连接多个数组不用concat来解决
Mar 24 #Javascript
jqeury-easyui-layout问题解决方法
Mar 24 #Javascript
让table变成exls的示例代码
Mar 24 #Javascript
You might like
discuz的php防止sql注入函数
2011/01/17 PHP
php懒人函数 自动添加数据
2011/06/28 PHP
ThinkPHP无限级分类原理实现留言与回复功能实例
2014/10/31 PHP
微信推送功能实现方式图文详解
2019/07/12 PHP
PHP7 新增常量
2021/03/09 PHP
js验证整数加保留小数点的简单实例
2013/12/02 Javascript
JS之Date对象和获取系统当前时间详解
2014/01/13 Javascript
javascript和jquery实现设置和移除文本框默认值效果代码
2015/01/13 Javascript
Javascript中判断对象是否为空
2015/06/10 Javascript
JavaScript中的this关键字使用详解
2015/08/14 Javascript
纯HTML5制作围住神经猫游戏-附源码下载
2015/08/23 Javascript
Bootstrap3学习笔记(二)之排版
2016/05/20 Javascript
jQuery中on绑定事件后引发的事件冒泡问题如何解决
2016/05/25 Javascript
Javascript函数中的arguments.callee用法实例分析
2016/09/16 Javascript
BootStrap 弹出层代码
2017/02/09 Javascript
基于angular2 的 http服务封装的实例代码
2017/06/29 Javascript
jq源码解析之绑在$,jQuery上面的方法(实例讲解)
2017/10/13 jQuery
javascript连接mysql与php通过odbc连接任意数据库的实例
2017/12/27 Javascript
Vue组件通信之Bus的具体使用
2017/12/28 Javascript
jquery操作checkbox的常用方法总结【附测试源码下载】
2019/06/10 jQuery
微信小程序连接服务器展示MQTT数据信息的实现
2020/07/14 Javascript
VUE中鼠标滚轮使div左右滚动的方法详解
2020/12/14 Vue.js
Python爬虫利用cookie实现模拟登陆实例详解
2017/01/12 Python
浅谈Python基础之I/O模型
2017/05/11 Python
python 读取dicom文件,生成info.txt和raw文件的方法
2019/01/24 Python
python获取交互式ssh shell的方法
2019/02/14 Python
Python 硬币兑换问题
2019/07/29 Python
tensorflow获取预训练模型某层参数并赋值到当前网络指定层方式
2020/01/24 Python
python 实现朴素贝叶斯算法的示例
2020/09/30 Python
python 利用toapi库自动生成api
2020/10/19 Python
Shopee菲律宾:在线购买和出售
2019/11/25 全球购物
应聘教师自荐信
2013/10/12 职场文书
基层党组织公开承诺书
2014/03/28 职场文书
2014年幼儿园园长工作总结
2014/12/17 职场文书
2016年大学生暑期社会实践活动总结
2016/04/06 职场文书
导游词幽默开场白
2019/06/26 职场文书