摘要:返回值為排序后的新數(shù)組。會有一個函數(shù)作為的參數(shù),該函數(shù)也有個參數(shù),分別為調(diào)用的數(shù)組的每一項元素對應(yīng)元素所在的位置表示該數(shù)組過濾方法。返回滿足條件的元素組成的數(shù)組。
原生javascript方法
var colors = []; var colors = ["red", "blue"];
if(arr instanceof Array) {}
如果網(wǎng)頁中包含多個框架,則需要使用下面的方式檢測數(shù)組
if(Array.isArray(arr)) {}
var colors = ["red", "yellow"]; colors.valueOf(); // > ["red", "yellow"]
var colors = ["red", "yellow"]; colors.toString(); // > "red,yellow"
從數(shù)組末尾添加元素,并返回新數(shù)組的長度
var colors = ["red", "yellow"]; colors.push("pink"); // > 3
從數(shù)組末尾刪除元素,并返回被刪除的元素
var colors = ["red", "yellow"]; colors.pop(); // > "yellow"
從數(shù)組頭部添加元素,并返回新數(shù)組的長度
var colors = ["green", "pink"]; colors.unshift("pink"); // > 3
從數(shù)組頭部刪除元素,并返回被刪除的元素
var colors = ["yellow", "orange"]; colors.shift(); // > "yellow"
反轉(zhuǎn)數(shù)組的順序,并返回重新排序之后的數(shù)組, 原數(shù)組會被改變
[1, 2, 3, "reer", "game", 2, 5].reverse(); // > [5, 2, "game", "reer", 3, 2, 1]
如果不傳參數(shù),默認情況下數(shù)組內(nèi)的元素會被轉(zhuǎn)換為字符串進行比較,因此一般不推薦直接使用默認的arr.sort()進行排序。
返回值為排序后的新數(shù)組。原數(shù)組會被改變
將數(shù)組內(nèi)數(shù)值元素從小到大排序。
var demo = [1, 4, 2, "reee", "name", "9", "doc"]; demo.sort(function(a, b)) { return a - b; } // > [1, 2, 4, "reee", "name", "9", "doc"]
將數(shù)組內(nèi)數(shù)值元素從大到小排序
var demo = [1, 4, 2, "reee", "name", "9", "doc"]; demo.sort(function(a, b) { return b - a; }) // > [4, 2, 1, "reee", "name", "9", "doc"]
參數(shù)中傳入元素或者數(shù)組, 會將該參數(shù)合并到arr中,返回合并后新的數(shù)組,原數(shù)組不會改變
var arr = [1, 3, "jake"]; arr.concat("rose", [2, "fi"]); // > [1, 3, "jake", "rose", 2, "fi"]
剪切數(shù)組,返回剪切之后的數(shù)組,元素不會改變
傳入一個參數(shù),表示起始位置,結(jié)束位置為最末尾
var arr = [4, 2, 1, "reee", "name", "9", "doc"]; arr.slice(2); // > [1, "reee", "name", "9", "doc"]
傳入2個參數(shù),表示起始位置與結(jié)束位置,但不包括結(jié)束位置所在的元素
var arr = [4, 2, 1, "reee", "name", "9", "doc"]; arr.slice(2, 4); // > [1, "reee"]
根據(jù)參數(shù)的不同,可以分別實現(xiàn)刪除,插入,替換元素的作用,會改變原始數(shù)組
刪除
傳入2個參數(shù), 分別表示起始位置與要刪除元素的個數(shù),返回被刪除掉的元素組成的數(shù)組
var arr = [4, 2, 1, "reee", "name", "9", "doc"]; arr.splice(2, 3); // > [1, "reee", "name"] // arr: [4, 2, "9", "doc"]
插入
傳入3個參數(shù), [起始位置 | 要刪除的項數(shù) 為0 | 要插入的元素], 最終返回刪除掉的元素組成的數(shù)組,因為這里刪除項數(shù)為0,因此會返回空數(shù)組
var arr = [2, 4, 6]; arr.splice(2, 0, "red", "green"); // > [] // arr: [2, 4, "red", "green", 6]
替換
傳入三個參數(shù), [ 起始位置 | 要刪除的項數(shù) 為1 | 要插入的元素 ],最終返回被刪除掉的元素組成的數(shù)組
var arr = [2, 4, 9]; arr.splice(1, 1, ["tim", "tom"]); // > [4] // arr: [2, ["tim", "tom"], 9]
總結(jié) 因此,這個方法會因為參數(shù)的不同而實現(xiàn)不同的功能,所有的參數(shù)從頭到尾依次為
[ 起始位置 | 要刪除元素的個數(shù) | 要插入元素的值,可以寫入多個值 ]
驗證數(shù)組中是否含有某個元素,返回第一個匹配到的元素在數(shù)組中所在的位置,如果沒有,則返回 -1
var arr = [2, "tim", 4, 5, 2]; arr.indexOf("tim"); // > 1 arr.indexOf("jake"); // > -1
驗證數(shù)組中是否含有某個元素,不過是從數(shù)組尾部開始查找,返回第一個匹配到的元素所在的位置,如果沒有,則返回-1
var arr = [2, "tim", 4, 5, 2]; arr.lastIndexOf("tim"); // > 1 arr.indexOf("jake"); // > -1
IE6, 7, 8 不支持indexOf與lastIndexOf方法
對數(shù)組中的每一項運行給定函數(shù),如果該函數(shù)對每一項都返回true,則返回true。會有一個函數(shù)作為every的參數(shù),該函數(shù)也有3個參數(shù),分別為
[ 調(diào)用every的數(shù)組的每一項元素 | 對應(yīng)元素所在的位置 | 表示該數(shù)組 ]
var numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1]; var everyRes = numbers.every(function(item, index, array) { return item > 2; }) // > false
對數(shù)組中的每一項運行給定函數(shù),如果該函數(shù)對其中一項返回true,則返回true。會有一個函數(shù)作為every的參數(shù),該函數(shù)也有3個參數(shù),分別為
[ 調(diào)用every的數(shù)組的每一項元素 | 對應(yīng)元素所在的位置 | 表示該數(shù)組 ]
var numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1]; var everyRes = numbers.some(function(item, index, array) { return item > 2; }) // > true
過濾方法。返回滿足條件的元素組成的數(shù)組。fn的參數(shù)為
[ 調(diào)用every的數(shù)組的每一項元素 | 對應(yīng)元素所在的位置 | 表示該數(shù)組 ]
var numbers = [1, 2, 3, 4, 5, 4, 3, 2, 1]; var everyRes = numbers.filter(function(item, index, array) { return item > 2; }) // > [ 3, 4, 5, 4, 3 ]
對數(shù)組的每一項進行計算等處理,返回處理結(jié)果組成的數(shù)組,fn的參數(shù)為
[ 調(diào)用every的數(shù)組的每一項元素 | 對應(yīng)元素所在的位置 | 表示該數(shù)組 ]
var numbers = [1, 2, 3, 3, 2, 1]; var everyRes = numbers.map(function(item, index, array) { return item > 2; }) // >[false, false, true, true, false, false]
遍歷數(shù)組,沒有返回值,fn的參數(shù)為
[ 調(diào)用every的數(shù)組的每一項元素 | 對應(yīng)元素所在的位置 | 表示該數(shù)組 ]
numbers.forEach(function(item, index) { // do something })
縮減方法。fn的參數(shù)為
[ 前一個元素 | 當前元素,從1開始 | 后一個元素的序列,從1開始計數(shù) | 表示該數(shù)組 ]
var values = [1, 2, 3, 4, 5]; var sum = values.reduce(function(prev, cur, index, array) { return prev + cur; }) // > 15 //每一次迭代之后的結(jié)果分別為 // [3, 3, 4, 5] // [6, 4, 5] // [10, 5] // 15
與reduce一模一樣,只是方向相反。
jQuery相關(guān)方法遍歷數(shù)組或者對象,fn有2個參數(shù),分別為, 比原生的for in 更加健壯
[ 數(shù)組的索引或者對象的key值 | 索引或者key值對應(yīng)的value值 ]
var arr = [1, 2, 3]; $.each(arr, function(key, value) { // do something });
跳過一次循環(huán) return | return true
終止循環(huán) return false
過濾方法,功能類同原生中的arr.filter(fn)。此處fn的參數(shù)如下
[ value: 對象/數(shù)組的值 | key值或者序列 ]
var arr = [ 1, 3, 6, 4 ]; $.grep(arr, function(val, key) { return val >= 3; }); // > [3, 6, 4] // arr : [ 1, 3, 6, 4 ] 不會改變
對每項進行處理,返回處理結(jié)果組成的數(shù)組,此處fn的參數(shù)如下
[ value: 對象/數(shù)組的值 | key值或者序列 ]
var arr = [1, 2, 5, 3]; $.map(arr, function(val, key) { return val * 10; }) // > [10, 30, 30, 20, 10] // 原數(shù)組不受影響
檢測某一個元素item是否存在與數(shù)組之中,返回其所在的位置,如果不在,則返回-1
$.inArray(3, [1, 2, 3]); // > 2
合并數(shù)組,會改變第一個參數(shù)的數(shù)組為合并之后的數(shù)組,返回合并之后的數(shù)組
var arr = [1, 3, 4]; var arr2 = [4, 3, 1]; $.merge(arr, arr2); // > [1, 3, 4, 4, 3, 1] // 為了防止第一個數(shù)組被改變,可以使用下面的方式來寫 $.merge($.merge([], arr), arr2);
過濾DOM數(shù)組中重復的元素
將類數(shù)組對象轉(zhuǎn)換為數(shù)組
將jQuery對象集合恢復成DOM數(shù)組
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91581.html
摘要:具體內(nèi)容請參考。感謝大家閱讀,另外,在這邊幫朋友推一個愛心眾籌,希望大家能夠奉獻點愛心,朋友母親,身患直腸癌,目前在北京武警總醫(yī)院接收治療,可留言留下您的聯(lián)系方式,日后感激大家 判斷數(shù)組是否包含某一特定元素是很常見的需求,javascript中有很多實現(xiàn)方法,今天有空匯總了一下,按兼容性由強到弱排序,返回類型一律為boolean: 假設(shè)數(shù)組為arr,目標元素為target 循環(huán)遍歷: ...
摘要:示例語法作用方法用于刪除并返回數(shù)組的最后一個元素。返回值一個新的字符串,該字符串值包含的一個子字符串,其內(nèi)容是從處到處的所有字符,其長度為減。返回值一個新的字符串,包含從的包括所指的字符處開始的個字符。 1.concat()語法:arrayObject.concat(array1,array2,......,arrayn)作用:concat() 方法用于連接兩個或多個數(shù)組。特征:該方法...
摘要:方法為數(shù)組中的每個元素都調(diào)用一次函數(shù)執(zhí)行如果沒有符合條件的元素返回對于空數(shù)組,函數(shù)是不會執(zhí)行的。不改變原數(shù)組和差不多,默認返回的是索引。 1. length屬性 && 檢測數(shù)組 length屬性不是只讀,可以設(shè)置該屬性,從數(shù)組的末尾移除項或添加新項 檢測數(shù)組: 一個全局作用域下(一個網(wǎng)頁),使用instanceof 兩個以上不同的全局執(zhí)行環(huán)境(網(wǎng)頁包含多個框架),使用Array....
摘要:將輸出新數(shù)組判斷數(shù)組中的每一項是否都滿足條件,都滿足返回,此方法相較于之前的幾個方法,返回值有差異,是一個布爾值。輸出數(shù)組用于將一組值轉(zhuǎn)化為數(shù)組輸出數(shù)組返回一個布爾值,表示某個數(shù)組中是否包含給定的值。 1、join(sep):將數(shù)組元素組合成字符串。以sep為分隔符,省略的話則默認使用逗號為分隔符。 var arr = [a,b,c]; console.log(arr.join(-))...
摘要:月下半旬攻略道題,目前已攻略題。目前簡單難度攻略已經(jīng)到題,所以后面會調(diào)整自己,在刷算法與數(shù)據(jù)結(jié)構(gòu)的同時,攻略中等難度的題目。 Create by jsliang on 2019-07-30 16:15:37 Recently revised in 2019-07-30 17:04:20 7 月下半旬攻略 45 道題,目前已攻略 100 題。 一 目錄 不折騰的前端,和咸魚有什么區(qū)別...
閱讀 1896·2021-11-11 16:55
閱讀 2105·2021-10-08 10:13
閱讀 755·2019-08-30 11:01
閱讀 2166·2019-08-29 13:19
閱讀 3293·2019-08-28 18:18
閱讀 2631·2019-08-26 13:26
閱讀 588·2019-08-26 11:40
閱讀 1879·2019-08-23 17:17