成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

數(shù)組方法匯總

cnio / 3171人閱讀

摘要:返回值為排序后的新數(shù)組。會有一個函數(shù)作為的參數(shù),該函數(shù)也有個參數(shù),分別為調(diào)用的數(shù)組的每一項元素對應(yīng)元素所在的位置表示該數(shù)組過濾方法。返回滿足條件的元素組成的數(shù)組。

原生javascript方法
創(chuàng)建數(shù)組
var colors = [];
var colors = ["red", "blue"];
檢測數(shù)組
if(arr instanceof Array) {}

如果網(wǎng)頁中包含多個框架,則需要使用下面的方式檢測數(shù)組

if(Array.isArray(arr)) {}
arr.valueOf()
var colors = ["red", "yellow"];
colors.valueOf();
// > ["red", "yellow"]
arr.toString()
var colors = ["red", "yellow"];
colors.toString();
// > "red,yellow"
arr.push(item)

從數(shù)組末尾添加元素,并返回新數(shù)組的長度

var colors = ["red", "yellow"];
colors.push("pink");
// > 3
arr.pop()

從數(shù)組末尾刪除元素,并返回被刪除的元素

var colors = ["red", "yellow"];
colors.pop();
// > "yellow"
arr.unshift(item)

從數(shù)組頭部添加元素,并返回新數(shù)組的長度

var colors = ["green", "pink"];
colors.unshift("pink");
// > 3
arr.shift()

從數(shù)組頭部刪除元素,并返回被刪除的元素

var colors = ["yellow", "orange"];
colors.shift();
// > "yellow"
arr.reverse()

反轉(zhuǎn)數(shù)組的順序,并返回重新排序之后的數(shù)組, 原數(shù)組會被改變

[1, 2, 3, "reer", "game", 2, 5].reverse();
// > [5, 2, "game", "reer", 3, 2, 1]
arr.sort(fn)

如果不傳參數(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"]
arr.concat(otherArr)

參數(shù)中傳入元素或者數(shù)組, 會將該參數(shù)合并到arr中,返回合并后新的數(shù)組,原數(shù)組不會改變

var arr = [1, 3, "jake"];
arr.concat("rose", [2, "fi"]);
// > [1, 3, "jake", "rose", 2, "fi"]
arr.slice()

剪切數(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"]
arr.splice()

根據(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ù) | 要插入元素的值,可以寫入多個值 ]

arr.indexOf(item)

驗證數(shù)組中是否含有某個元素,返回第一個匹配到的元素在數(shù)組中所在的位置,如果沒有,則返回 -1

var arr = [2, "tim", 4, 5, 2];
arr.indexOf("tim");
// > 1
arr.indexOf("jake");
// > -1
arr.lastIndexOf(item)

驗證數(shù)組中是否含有某個元素,不過是從數(shù)組尾部開始查找,返回第一個匹配到的元素所在的位置,如果沒有,則返回-1

var arr = [2, "tim", 4, 5, 2];
arr.lastIndexOf("tim");
// > 1
arr.indexOf("jake");
// > -1
IE6, 7, 8 不支持indexOf與lastIndexOf方法
arr.every()

對數(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
arr.some()

對數(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
arr.filter(fn)

過濾方法。返回滿足條件的元素組成的數(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 ]
arr.map(fn)

對數(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]
arr.forEach(fn)

遍歷數(shù)組,沒有返回值,fn的參數(shù)為
[ 調(diào)用every的數(shù)組的每一項元素 | 對應(yīng)元素所在的位置 | 表示該數(shù)組 ]

numbers.forEach(function(item, index) {
    // do something
})
arr.reduce(fn)

縮減方法。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
arr.reduceRight(fn)

與reduce一模一樣,只是方向相反。

jQuery相關(guān)方法
$.each(arr, fn)

遍歷數(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

$.grep(arr, fn)

過濾方法,功能類同原生中的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 ] 不會改變
$.map(arr, fn)

對每項進行處理,返回處理結(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ù)組不受影響
$.inArray(item, array)

檢測某一個元素item是否存在與數(shù)組之中,返回其所在的位置,如果不在,則返回-1

$.inArray(3, [1, 2, 3]);
// > 2
$.merge(arr1, arr2)

合并數(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);
$.unique(arr)

過濾DOM數(shù)組中重復的元素

$.makeArray(obj)

將類數(shù)組對象轉(zhuǎn)換為數(shù)組

$(elem).toArray()

將jQuery對象集合恢復成DOM數(shù)組

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91581.html

相關(guān)文章

  • Javascript判斷數(shù)組是否包含特定元素方法匯總

    摘要:具體內(nèi)容請參考。感謝大家閱讀,另外,在這邊幫朋友推一個愛心眾籌,希望大家能夠奉獻點愛心,朋友母親,身患直腸癌,目前在北京武警總醫(yī)院接收治療,可留言留下您的聯(lián)系方式,日后感激大家 判斷數(shù)組是否包含某一特定元素是很常見的需求,javascript中有很多實現(xiàn)方法,今天有空匯總了一下,按兼容性由強到弱排序,返回類型一律為boolean: 假設(shè)數(shù)組為arr,目標元素為target 循環(huán)遍歷: ...

    impig33 評論0 收藏0
  • 排序算法終極匯總

    摘要:本文對種排序方法進行匯總。自頂向下的歸并排序算法歸并排序自頂向下分治思想的最經(jīng)典的一個例子。另外,快排序的內(nèi)循環(huán)比大多數(shù)排序算法都短?;舅惴炫判蚴且环N分治的算法,將一個數(shù)組分成兩個子數(shù)組,將兩部分獨立排序。 本文對9種排序方法進行匯總。分別是: 插入排序 選擇排序 歸并排序 冒泡排序 堆排序 快排序 計數(shù)排序 基數(shù)排序 桶排序。參照《算法》第四版這本書,把排序需要的公共的方法抽象出...

    voyagelab 評論0 收藏0
  • JavaScript中操作數(shù)組的常用函數(shù)匯總

    摘要:示例語法作用方法用于刪除并返回數(shù)組的最后一個元素。返回值一個新的字符串,該字符串值包含的一個子字符串,其內(nèi)容是從處到處的所有字符,其長度為減。返回值一個新的字符串,包含從的包括所指的字符處開始的個字符。 1.concat()語法:arrayObject.concat(array1,array2,......,arrayn)作用:concat() 方法用于連接兩個或多個數(shù)組。特征:該方法...

    beita 評論0 收藏0
  • Array() 方法匯總

    摘要:方法為數(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....

    JessYanCoding 評論0 收藏0
  • javascript數(shù)組方法學習匯總

    摘要:將輸出新數(shù)組判斷數(shù)組中的每一項是否都滿足條件,都滿足返回,此方法相較于之前的幾個方法,返回值有差異,是一個布爾值。輸出數(shù)組用于將一組值轉(zhuǎn)化為數(shù)組輸出數(shù)組返回一個布爾值,表示某個數(shù)組中是否包含給定的值。 1、join(sep):將數(shù)組元素組合成字符串。以sep為分隔符,省略的話則默認使用逗號為分隔符。 var arr = [a,b,c]; console.log(arr.join(-))...

    zebrayoung 評論0 收藏0
  • LeetCode 攻略 - 2019 年 7 月下半月匯總(100 題攻略)

    摘要:月下半旬攻略道題,目前已攻略題。目前簡單難度攻略已經(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ū)別...

    tain335 評論0 收藏0

發(fā)表評論

0條評論

cnio

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<