加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 教程 > 正文

jquery基础教程之数组运用详解

发布时间:2023-10-26 15:28:48 所属栏目:教程 来源:
导读: $.each(array, [callback]) 遍历[常用]

解释: 不同于例遍jQuery对象的$().each()方法,此方法可用于例遍任何对象。回调函数拥有两个参数:第一个为对象的成员或数组的索引, 第二个为对应变量或内容. 如果需要退出
 $.each(array, [callback]) 遍历[常用]
 
解释: 不同于例遍jQuery对象的$().each()方法,此方法可用于例遍任何对象。回调函数拥有两个参数:第一个为对象的成员或数组的索引, 第二个为对应变量或内容. 如果需要退出each循环可使回调函数返回false, 其它返回值将被忽略。
 
each遍历,相信都不陌生,在平常的事件处理中,是for循环的变体,但比for循环强大。在数组中,它可以轻松的攻取数组索引及对应的值。例:
 
代码如下:
 
var _mozi=['墨家','墨子','墨翟','兼爱非攻','尚同尚贤']; //本文所用到的数组, 下同
 
$.each(_mozi,function(key,val){
 
    //回调函数有两个参数,第一个是元素索引,第二个为当前值
 
    alert('_mozi数组中 ,索引 : '+key+' 对应的值为: '+val);
 
});
 
相对于原生的for..in,each更强壮一点。for..in也可以遍历数组,并返回对应索引,但值是需要通过arrName[key]来获取。
 
2. $.grep(array, callback, [invert])过滤数组[常用]
 
解释: 使用过滤函数过滤数组元素.此函数至少传递两个参数(第三个参数为true或false,对过滤函数返回值取反,个人觉得用处不大): 待过滤数组和过滤函数. 过滤函数必须返回true以保留元素或 false 以删除元素. 另外,过滤函数还可以是可设置为一个字条串。
 
代码如下:
 
$.grep(_mozi,function(val,key){
 
    //过滤函数有两个参数,第一个为当前元素,第二个为元素索引
 
    if(val=='墨子'){
 
        alert('数组值为 墨子 的下标是: '+key);
 
    }
 
});
 
var _moziGt1=$.grep(_mozi,function(val,key){
 
    return key>1;
 
});
 
alert('_mozi数组中索引值大于1的元素为: '+_moziGt1);
 
var _moziLt1=$.grep(_mozi,function(val,key){
 
    return key>1;
 
},true);
 
//此处传入了第三个可靠参数,对过滤函数中的返回值取反
 
alert('_mozi数组中索引值小于等于1的元素为: '+_moziLt1);
 
3. $.map(array,[callback])按给定条件转换数组 [一般]
 
解释:作为参数的转换函数会为每个数组元素调用, 而且会给这个转换函数传递一个表示被转换的元素作为参数. 转换函数可以返回转换后的值、null(删除数组中的项目)或一个包含值的数组, 并扩展至原始数组中。
 
这个是个很强大的方法,但并不常用. 它可以根据特定条件,更新数组元素值,或根据原值扩展一个新的副本元素。
 
代码如下:
 
var _mapArrA=$.map(_mozi,function(val){
 
    return val+'[新加]';
 
});
 
var _mapArrB=$.map(_mozi,function(val){
 
    return val=='墨子' ? '[只给墨子加]'+val : val;
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章