国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專(zhuān)欄INFORMATION COLUMN

javascript 數(shù)組的常用方法

denson / 2121人閱讀

摘要:實(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ù)組的一些方法全部匯總在一起,方便查看和增加記憶.

創(chuàng)建數(shù)組
let arr = ["apple", "banana"];
console.log(arr, "---------訪問(wèn)數(shù)組"); //[ "apple","banana" ]
通過(guò)索引訪問(wèn)元素
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"
遍歷數(shù)組
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"]
})
push() 添加元素到數(shù)組末尾
let arr = ["apple", "banana"];
arr.push("orange");
console.log(arr, "----添加元素到數(shù)組末尾"); // ["apple", "banana", "orange" ]
pop() 刪除數(shù)組末尾元素
let arr = ["apple", "banana","orange"];
arr.pop();
console.log(arr, "----刪除數(shù)組末尾元素"); //["apple", "banana"]
shift() 刪除數(shù)組最前面的元素
let arr = ["apple", "banana"];
arr.shift();
console.log(arr, "----刪除數(shù)組最前面的元素") //[ "banana" ]
unshift() 添加元素到數(shù)組的頭部
let arr = ["banana"];
arr.unshift("eggs");
console.log(arr, "----添加元素到數(shù)組的頭部")  //[ "eggs", "banana" ]
indexOf() 查看某個(gè)某個(gè)元素在數(shù)組中的位置,存在就是當(dāng)前下標(biāo),如果不存在就為-1;
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
splice是數(shù)組中最強(qiáng)大的功能之一,增,刪,改
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è)元素")
slice 不會(huì)改變?cè)瓟?shù)組
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" ]
Array.from() 方法從一個(gè)類(lèi)似數(shù)組或可迭代對(duì)象中創(chuàng)建一個(gè)新的數(shù)組實(shí)例。
const bar = ["a", "b", "c"];
Array.from(bar);
const foo = Array.from("foo");
console.log(foo); //[ "f", "o", "o" ] 
Array.isArray() 用于確定傳遞的值是否是一個(gè) Array。
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
Array.of() 方法創(chuàng)建一個(gè)具有可變數(shù)量參數(shù)的新數(shù)組實(shí)例
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 ]
concat() 方法用于合并兩個(gè)或多個(gè)數(shù)組。此方法不會(huì)更改現(xiàn)有數(shù)組,而是返回一個(gè)新數(shù)組。
let array1 = ["a", "b"];
let array2 = ["1", "2"];
let array3 = [].concat(array1, array2);
console.log(array3) //[ "a", "b", "1", "2" ]
array.copyWithin(target, start, end)

方法淺復(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" ]
entries() 方法返回一個(gè)新的Array Iterator對(duì)象,該對(duì)象包含數(shù)組中每個(gè)索引的鍵/值對(duì)。
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ù)組
keys()方法返回一個(gè)新的Array迭代器,它包含數(shù)組中每個(gè)索引的鍵。 返回的是下標(biāo)
values() 方法返回一個(gè)新的 Array Iterator 對(duì)象,該對(duì)象包含數(shù)組每個(gè)索引的值。
for (let index of ["a", "b"].keys()) {
    console.log(index);
}
// 0  
// 1  
every() 方法測(cè)試數(shù)組的所有元素是否都通過(guò)了指定函數(shù)的測(cè)試。
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
some() 方法測(cè)試數(shù)組中的某些元素是否通過(guò)由提供的函數(shù)實(shí)現(xiàn)的測(cè)試。
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
fill() 方法用一個(gè)固定值填充一個(gè)數(shù)組中從起始索引到終止索引內(nèi)的全部元素。
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 ]
filter() 方法創(chuàng)建一個(gè)新數(shù)組, 其包含通過(guò)所提供函數(shù)實(shí)現(xiàn)的測(cè)試的所有元素。
let filter = (value) => {
    return value > 10
}
console.log([15, 13, 2, 16, 3].filter(filter))  // 15, 13, 16 ]
find() 方法返回?cái)?shù)組中滿(mǎn)足提供的測(cè)試函數(shù)的第一個(gè)元素的值。否則返回 undefined。
console.log([15, 13, 2, 16, 3].find(filter))  // 15 返回第一個(gè)滿(mǎn)足條件的值  否則undefined
findIndex()方法返回?cái)?shù)組中滿(mǎn)足提供的測(cè)試函數(shù)的第一個(gè)元素的索引。否則返回-1。
console.log([15, 13, 2, 16, 3].findIndex(filter))  // 0 返回第一個(gè)滿(mǎn)足條件的下表  否則-1
forEach() 方法對(duì)數(shù)組的每個(gè)元素執(zhí)行一次提供的函數(shù)。 //item是值,index下標(biāo),array是原數(shù)組
fillArr.forEach((item, index, array) => console.log(item))
includes() 方法用來(lái)判斷一個(gè)數(shù)組是否包含一個(gè)指定的值,根據(jù)情況,如果包含則返回
console.log(fillArr.includes(2)) //true 檢查數(shù)組中是否有該值有為true,否則false
console.log(fillArr.includes(4)) //false  
indexOf()方法返回在數(shù)組中可以找到一個(gè)給定元素的第一個(gè)索引,如果不存在,則返回-1。
console.log(fillArr.indexOf(2))  //0
console.log(fillArr.indexOf(4))  //-1 
join() 方法將一個(gè)數(shù)組(或一個(gè)類(lèi)數(shù)組對(duì)象)的所有元素連接成一個(gè)字符串并返回這個(gè)字符串。
let joinArr = ["Wind", "Rain", "Fire"];
console.log(joinArr.join());  //Wind,Rain,Fire
lastIndexOf() 方法返回指定元素(也即有效的 JavaScript 值或變量)在數(shù)組中的最后一個(gè)的索引,如果不存在則返回 -1。從數(shù)組的后面向前查找,從 fromIndex 處開(kāi)始。
console.log(["a","b"].lastIndexOf("a"));   //0  從后面往前面找
map() 方法創(chuàng)建一個(gè)新數(shù)組,其結(jié)果是該數(shù)組中的每個(gè)元素都調(diào)用一個(gè)提供的函數(shù)后返回的結(jié)果。
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"
reduce() 方法對(duì)累加器和數(shù)組中的每個(gè)元素(從左到右)應(yīng)用一個(gè)函數(shù),將其減少為單個(gè)值。
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 從左往右
reduceRight() 方法接受一個(gè)函數(shù)作為累加器(accumulator)和數(shù)組的每個(gè)值(從右到左)將其減少為單個(gè)值。
console.log(reduceArr.reduceRight(reduce))  //21 從右往左
reverse() 方法將數(shù)組中元素的位置顛倒。
console.log(reduceArr.reverse()) //[ 6, 5, 4, 3, 2, 1 ] 數(shù)組順序顛倒
sort() 數(shù)組的元素進(jìn)行排序,并返回?cái)?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)
toLocaleString()返回一個(gè)字符串表示數(shù)組中的元素。數(shù)組中的元素將使用各自的 toLocaleString 方法轉(zhuǎn)成字符串,
  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

相關(guān)文章

  • JavaScript 常用方法

    摘要:常用方法作用向從數(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(...

    ranwu 評(píng)論0 收藏0
  • Javascript數(shù)組常用方法

    摘要:數(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;/...

    verano 評(píng)論0 收藏0
  • JavaScript Array對(duì)象常用方法

    摘要:省略則對(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è)...

    wangdai 評(píng)論0 收藏0
  • javascript數(shù)組常用方法

    摘要:數(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)為^_^)最為...

    GraphQuery 評(píng)論0 收藏0
  • JavaScript數(shù)組——常用數(shù)組方法匯總

    摘要:本文記錄關(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ù)組末尾增加新的...

    HollisChuang 評(píng)論0 收藏0
  • [ ES6 ] 快速掌握常用 ES6 (二)

    摘要:本系列文章適合快速掌握入門(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ì)之前文章...

    hidogs 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<