摘要:實(shí)際使用的是這個(gè)注意,是,比數(shù)組的長(zhǎng)度大每次迭代時(shí)更新這里可以看到更新后的都是遍歷迭代器結(jié)束才是遍歷完畢,輸出的數(shù)組方法返回一個(gè)新的迭代器,它包含數(shù)組中每個(gè)索引的鍵。方法對(duì)累加器和數(shù)組中的每個(gè)元素從左到右應(yīng)用一個(gè)函數(shù),將其減少為單個(gè)值。
學(xué)習(xí)javascript的過(guò)程中,總是容易array忘記方法,把數(shù)組的一些方法全部匯總在一起,方便查看和增加記憶.
let arr = ["apple", "banana"]; console.log(arr, "---------訪問(wèn)數(shù)組"); //[ "apple","banana" ]
let arr = ["apple", "banana"]; let first = arr[0]; console.log(first, "----通過(guò)索引訪問(wèn)數(shù)組"); //"apple" console.log(arr[arr.length - 1], "-------訪問(wèn)數(shù)組中最后一位元素") //"banana"
let arr = ["apple", "banana"]; arr.forEach((item, index, array) => { console.log(item, "------item") //"apple" "banana" console.log(index, "------index") // 0,1 console.log(array, "-----array") //["apple","banana"] })
let arr = ["apple", "banana"]; arr.push("orange"); console.log(arr, "----添加元素到數(shù)組末尾"); // ["apple", "banana", "orange" ]
let arr = ["apple", "banana","orange"]; arr.pop(); console.log(arr, "----刪除數(shù)組末尾元素"); //["apple", "banana"]
let arr = ["apple", "banana"]; arr.shift(); console.log(arr, "----刪除數(shù)組最前面的元素") //[ "banana" ]
let arr = ["banana"]; arr.unshift("eggs"); console.log(arr, "----添加元素到數(shù)組的頭部") //[ "eggs", "banana" ]
let arr = [ "eggs","banana"]; let index = arr.indexOf("banana"); console.log(index, "------查看某個(gè)某個(gè)元素在數(shù)組中的位置;") //1 //-------------------- let index1 = arr.indexOf("watermelon"); console.log(index1, "------查看某個(gè)某個(gè)元素在數(shù)組中的位置;") //-1
let arr = [ "eggs","banana"]; splice(start,end,string) start是開(kāi)始下標(biāo)的位置 end是刪除幾個(gè)元素 string是插入或替換的元素 arr.splice(0, 1, "grapes"); //在0的位置刪除一個(gè)元素,并且加入一個(gè)元素 ,刪除插入 console.log(arr,"------") //[ "grapes", "banana" ] "------" arr.splice(1, 2, "fruits"); //在下標(biāo)為1的位置插入2個(gè)元素,如果后面只傳了一個(gè)就插入一個(gè) console.log(arr,"------") //[ "grapes", "fruits" ] "------" arr.splice(2, 2, "fruits", "fruits"); //在下標(biāo)為2的位置插入2個(gè)元素 console.log(arr,"------") //[ "grapes", "fruits" ] "------" arr.splice(0, 1); //刪除元素 console.log(arr, "---通過(guò)索引刪除某個(gè)元素")
let arr=[ "fruits", "fruits", "fruits" ]; let copyArr = arr.slice(); //拷貝數(shù)組 console.log(copyArr) //[ "fruits", "fruits", "fruits" ] let sliceArr = arr.slice(0, 1); //獲取元素 console.log(sliceArr) //[ "fruits" ]
const bar = ["a", "b", "c"]; Array.from(bar); const foo = Array.from("foo"); console.log(foo); //[ "f", "o", "o" ]
console.log(Array.isArray([1, 2, 3])) //true console.log(Array.isArray("str")) //false console.log(Array.isArray({ "foo": "1" })) //false console.log(Array.isArray(null)) //false console.log(Array.isArray(undefined)) //false
console.log(Array.of(5)) //[5] 創(chuàng)建一個(gè)數(shù)組為[5] console.log(Array.of(1, 2, 3)) //[1,2,3] console.log(Array.of(1, [1, 23], 3)) //[ 1, [ 1, 23 ], 3 ]
let array1 = ["a", "b"]; let array2 = ["1", "2"]; let array3 = [].concat(array1, array2); console.log(array3) //[ "a", "b", "1", "2" ]
方法淺復(fù)制數(shù)組的一部分到同一數(shù)組中的另一個(gè)位置,并返回它,而不修改其大小。
target 必需。復(fù)制到指定目標(biāo)索引位置。 start 必需。元素復(fù)制的起始位置。 end 可選。停止復(fù)制的索引位置 (默認(rèn)為 array.length) let copyWithinArr = ["alpha", "beta", "copy", "delta"].copyWithin(1, 2, 3); 1=="beta" 2=="copy" 3=="delta" console.log(copyWithinArr) // [ "alpha", "copy", "copy", "delta" ] let copyWithinArr1 = ["alpha", "beta", "copy", "delta"].copyWithin(2, 0); console.log(copyWithinArr1) //[ "alpha", "beta", "alpha", "beta" ]
var entries = ["a", "b", "c"]; var iterator = entries.entries(); console.log(iterator, "---") console.log(iterator.next().value, "---") console.log(iterator.next()) var iter = entries.entries(); var a = []; // for(var i=0; i< arr.length; i++){ // 實(shí)際使用的是這個(gè) for (var i = 0; i < arr.length + 1; i++) { // 注意,是length+1,比數(shù)組的長(zhǎng)度大 var tem = iter.next(); // 每次迭代時(shí)更新next console.log(tem.done); // 這里可以看到更新后的done都是false if (tem.done !== true) { // 遍歷迭代器結(jié)束done才是true console.log(tem.value); a[i] = tem.value; } } console.log(a); // [ [ 0, "a" ], [ 1, "b" ], [ 2, "c" ] ] 遍歷完畢,輸出next.value的數(shù)組
for (let index of ["a", "b"].keys()) { console.log(index); } // 0 // 1
function isBigEnough(element, index, array) { return (element >= 10); } var passed = [12, 5, 8, 130, 44].every(isBigEnough); // passed is false passed = [12, 54, 18, 130, 44].every(isBigEnough); // passed is true
console.log([1,2,3,4,5].some(isBigEnough),"----some"); //一個(gè)都沒(méi)有通過(guò)false // passed is false console.log([12, 54, 18, 1,2].some(isBigEnough),"--------some"); //只要有一個(gè)通過(guò)即為true // passed is true
arr.fill(value,start,end) let fillArr = [1, 2, 3, 4, 5]; console.log(fillArr.fill(3)) //[ 3, 3, 3, 3, 3 ] console.log(fillArr.fill(2, 0, 2)) //[ 2, 2, 3, 3, 3 ] console.log(fillArr.fill(5, 1)) // 2, 5, 5, 5, 5 ]
let filter = (value) => { return value > 10 } console.log([15, 13, 2, 16, 3].filter(filter)) // 15, 13, 16 ]
console.log([15, 13, 2, 16, 3].find(filter)) // 15 返回第一個(gè)滿(mǎn)足條件的值 否則undefined
console.log([15, 13, 2, 16, 3].findIndex(filter)) // 0 返回第一個(gè)滿(mǎn)足條件的下表 否則-1
fillArr.forEach((item, index, array) => console.log(item))
console.log(fillArr.includes(2)) //true 檢查數(shù)組中是否有該值有為true,否則false console.log(fillArr.includes(4)) //false
console.log(fillArr.indexOf(2)) //0 console.log(fillArr.indexOf(4)) //-1
let joinArr = ["Wind", "Rain", "Fire"]; console.log(joinArr.join()); //Wind,Rain,Fire
console.log(["a","b"].lastIndexOf("a")); //0 從后面往前面找
let numbers=[1,2,3,45,7,8,9]; let doubles=numbers.map(x=>x+1); console.log(doubles,"------map") //[ 2, 3, 4, 46, 8, 9, 10 ] "------map"
const reduceArr=[1,2,3,4,5,6]; const reduce=(accumulator,currentValue)=>{ console.log(accumulator,"-------accumulator"); //累加的值 console.log(currentValue,"-------currentValue"); //當(dāng)前元素 return accumulator+currentValue }; console.log(reduceArr.reduce(reduce)) //21 從左往右
console.log(reduceArr.reduceRight(reduce)) //21 從右往左
console.log(reduceArr.reverse()) //[ 6, 5, 4, 3, 2, 1 ] 數(shù)組順序顛倒
let items = [ { name: "Edward", value: 21 }, { name: "Sharpe", value: 37 }, { name: "And", value: 45 }, { name: "The", value: -12 }, { name: "Magnetic" ,value :0}, { name: "Zeros", value: 37 } ]; items.sort((a,b)=>{ return a.value-b.value }) console.log(items) items.sort((a,b)=>{ var nameA = a.name.toUpperCase(); // ignore upper and lowercase var nameB = b.name.toUpperCase(); // ignore upper and lowercase if (nameA < nameB) { return -1; } if (nameA > nameB) { return 1; } // names must be equal return 0; // return nameA-nameB 轉(zhuǎn)成NAN }) console.log(items)
let str=[1,2,3,4,5]; console.log(str.toLocaleString()) //1,2,3,4,5
希望大家喜歡,也希望大家指點(diǎn)錯(cuò)誤,也可以加入qq群439667347,大家一起討論,一起進(jìn)步,后續(xù)更新中...
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/107624.html
摘要:常用方法作用向從數(shù)組中添加刪除項(xiàng)目,然后返回被刪除的項(xiàng)目。注釋該方法并不會(huì)修改數(shù)組,而是返回一個(gè)子數(shù)組。語(yǔ)法表示數(shù)組開(kāi)始選定的位置表示數(shù)組結(jié)束選定的位置作用從已有的數(shù)組末尾增加一個(gè)元素。 JavaScript 常用方法 1. splice() 作用:向/從數(shù)組中添加/刪除項(xiàng)目,然后返回被刪除的項(xiàng)目。 注釋?zhuān)涸摲椒〞?huì)改變?cè)紨?shù)組。 語(yǔ)法:arrayObject.splice(...
摘要:數(shù)組常用方法介紹刪除數(shù)組最后一位元素。開(kāi)始下標(biāo)刪除個(gè)數(shù),插入元素可以多個(gè)注意當(dāng)數(shù)組執(zhí)行上面的這些方法時(shí),都會(huì)修改原數(shù)組。輸出從數(shù)組中找出所有符合指定條件的元素。內(nèi)容返回將數(shù)組合成一個(gè)值。合并數(shù)組或合并數(shù)組的值。 JavaScript 數(shù)組常用方法介紹 array.pop – 刪除數(shù)組最后一位元素。 var arr = [1, 2, 3]; arr.pop();// 返回 3 arr;/...
摘要:省略則對(duì)數(shù)組元素進(jìn)行排序返回該數(shù)組從數(shù)組中添加刪除項(xiàng)目返回被刪除的元素插入替換刪除 Array對(duì)象常用方法 不改變?cè)瓟?shù)組 concat() join() slice() toString() 改變?cè)瓟?shù)組 pop() push() reverse() shift() unshift() sort() splice() 不改變?cè)瓟?shù)組 array.concat(array) 連接兩個(gè)...
摘要:數(shù)組常用方法數(shù)組作為中常用的數(shù)據(jù)類(lèi)型使我們用的最多的在其他地方可以搜索出很多對(duì)其方法的總結(jié)本文列舉了筆者認(rèn)為的個(gè)人認(rèn)為最為重要的一系列方法字符串?dāng)?shù)組轉(zhuǎn)換數(shù)組字符串轉(zhuǎn)換轉(zhuǎn)換時(shí)可以添加符號(hào)還有一個(gè)是查找元素返回第一個(gè)與參數(shù)相同的元素的索引。 js數(shù)組常用方法 數(shù)組作為js中常用的數(shù)據(jù)類(lèi)型使我們用的最多的, 在其他地方可以搜索出很多對(duì)其方法的總結(jié), 本文列舉了筆者認(rèn)為的(個(gè)人認(rèn)為^_^)最為...
摘要:本文記錄關(guān)于數(shù)組的一些常用方法,搜集總結(jié)。對(duì)于數(shù)組中的每個(gè)元素,都會(huì)調(diào)用函數(shù)一次。返回值是一個(gè)新數(shù)組,其中的每個(gè)元素均為關(guān)聯(lián)的原始數(shù)組元素的回調(diào)函數(shù)返回值。 本文記錄關(guān)于js數(shù)組的一些常用方法,搜集總結(jié)。 主要思路: 1. 方法功能是什么 2. 傳遞的參數(shù)是什么 3. 返回值是什么 4. 原來(lái)的數(shù)組是否改變 第一組:關(guān)于數(shù)組的增加、刪除和修改 1.push 向數(shù)組末尾增加新的...
摘要:本系列文章適合快速掌握入門(mén)語(yǔ)法,想深入學(xué)習(xí)的小伙伴可以看看阮一峰老師的入門(mén)本篇文章是對(duì)之前文章的一個(gè)補(bǔ)充,可以使代碼更簡(jiǎn)潔函數(shù)參數(shù)默認(rèn)值在傳統(tǒng)語(yǔ)法中如果想設(shè)置函數(shù)默認(rèn)值一般我們采用判斷的形式在新的語(yǔ)法中我們可以在參數(shù)聲明的同時(shí)賦予默認(rèn)值參數(shù) 本系列文章適合快速掌握 ES6 入門(mén)語(yǔ)法,想深入學(xué)習(xí) ES6 的小伙伴可以看看阮一峰老師的《ECMAScript 6 入門(mén)》 本篇文章是對(duì)之前文章...
閱讀 2570·2021-11-22 12:05
閱讀 3456·2021-10-14 09:42
閱讀 1688·2021-07-28 00:15
閱讀 1991·2019-08-30 11:08
閱讀 1488·2019-08-29 17:31
閱讀 933·2019-08-29 16:42
閱讀 2341·2019-08-26 11:55
閱讀 2122·2019-08-26 11:49