淺析jquery數(shù)組刪除指定元素的方法:grep()
遇到的問題
今天遇到一個問題,刪除數(shù)組中的一個指定元素,并返回新的數(shù)組。
我定義的js數(shù)組是這樣的:
var sexList=new Array[3]; sexList[0]="1"; sexList[1]="2"; sexList[2]="";
想達(dá)到的效果
我想達(dá)到的效果是這樣的:
刪除索引=1的元素,并返回新數(shù)組。
返回的結(jié)果是:
var sexList=new Array("1","");
我們知道,原生的javascript有一個函數(shù):splice() 方法,可以刪除數(shù)組中的指定元素。
關(guān)于splice()方法的具體用法,可以參考w3school的描述,這里不多做解釋:http://www.w3school.com.cn/jsref/jsref_splice.asp
使用splice()的實(shí)現(xiàn)代碼
我的實(shí)現(xiàn)代碼:
var sexList=new Array[3]; sexList[0]="1"; sexList[1]="2"; sexList[2]=""; sexList=sexList.splice(1,1);
但是我發(fā)現(xiàn)我的數(shù)組使用這種方式時,返回的數(shù)組是不符合預(yù)期的。返回的是個空字符串。
后來網(wǎng)上搜索jquery的相關(guān)API,發(fā)現(xiàn)一個函數(shù):grep()
grep()使用方法說明
jQuery.grep(array, callback, [invert])
概述
使用過濾函數(shù)過濾數(shù)組元素。
此函數(shù)至少傳遞兩個參數(shù):待過濾數(shù)組和過濾函數(shù)。過濾函數(shù)必須返回 true 以保留元素或 false 以刪除元素。
參數(shù)
| 英文名 | 參數(shù)中文說明 |
|---|---|
| array: | 待過濾數(shù)組。 |
| callback: | 此函數(shù)將處理數(shù)組每個元素。第一個參數(shù)為當(dāng)前元素,第二個參數(shù)而元素索引值。此函數(shù)應(yīng)返回一個布爾值。另外,此函數(shù)可設(shè)置為一個字符串,當(dāng)設(shè)置為字符串時,將視為“l(fā)ambda-form”(縮寫形式?),其中 a 代表數(shù)組元素,i 代表元素索引值。如“a > 0”代表“function(a){ return a > 0; }”。 |
| invert: | 如果 "invert" 為 false 或?yàn)樵O(shè)置,則函數(shù)返回?cái)?shù)組中由過濾函數(shù)返回 true 的元素,當(dāng)"invert" 為 true,則返回過濾函數(shù)中返回 false 的元素集。 |
使用grep()的實(shí)現(xiàn)代碼
sexList=$.grep(sexList,function(n,i){
return i!=1;
});
function(n,i)中
n:表示數(shù)組的單個實(shí)體,
i:表示數(shù)組的索引。
以上這篇淺析jquery數(shù)組刪除指定元素的方法:grep()就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
jQuery 1.3 和 Validation 驗(yàn)證插件1.5.1
jQuery 1.3已經(jīng)新鮮出爐了,你可以通過jQuery 的官方博客查看相關(guān)細(xì)節(jié)。jQuery三歲了!2009-07-07
jQuery Easyui DataGrid點(diǎn)擊某個單元格即進(jìn)入編輯狀態(tài)焦點(diǎn)移開后保存數(shù)據(jù)
這篇文章主要介紹了jQuery Easyui DataGrid點(diǎn)擊某個單元格即進(jìn)入編輯狀態(tài)焦點(diǎn)移開后保存數(shù)據(jù)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-08-08
深入淺析ng-bootstrap 組件集中 tabset 組件的實(shí)現(xiàn)分析
這篇文章主要介紹了ng-bootstrap 組件集中 tabset 組件的實(shí)現(xiàn)分析 ,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07
Jquery change(fontsize,background) 改變顏色與背景的代碼
基于Jquery的改變顏色與背景的代碼,對于學(xué)習(xí)jquery的朋友可以參考下。2010-05-05
jQuery特殊符號轉(zhuǎn)義的實(shí)現(xiàn)
下面小編就為大家?guī)硪黄猨Query特殊符號轉(zhuǎn)義的實(shí)現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11
jq選項(xiàng)卡鼠標(biāo)延遲的插件實(shí)例
jq選項(xiàng)卡鼠標(biāo)延遲的插件實(shí)例,需要的朋友可以參考一下2013-05-05

