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

資訊專欄INFORMATION COLUMN

「JavaScript」Array方法的詳細(xì)總結(jié)及常用數(shù)組操作(附完整示例)

Alfred / 1436人閱讀

摘要:數(shù)組索引只是具有整數(shù)名稱的枚舉屬性,并且與通用對(duì)象屬性相同。利用的解構(gòu)賦值解構(gòu)賦值尾遞歸優(yōu)化遞歸非常耗內(nèi)存,因?yàn)樾枰瑫r(shí)保存成千上百個(gè)調(diào)用幀,很容易發(fā)生棧溢出。而尾遞歸的實(shí)現(xiàn),往往需要改寫遞歸函數(shù),確保最后一步只調(diào)用自身。

一.前言

因?yàn)樵诠ぷ鳟?dāng)中,經(jīng)常使用到j(luò)s的數(shù)組,而其中對(duì)數(shù)組方法的使用也是很頻繁的,所以總是會(huì)有弄混或者概念不夠清晰的狀況,所以,寫下這篇文章整理一番,本文有對(duì)幾乎所有數(shù)組的方法的介紹,此外還有非常實(shí)用的一些數(shù)組操作比如亂序去重和斐波那契數(shù)列求值等等,總之干貨滿滿~~

二.JS中的Array方法 1.檢測(cè)數(shù)組
   //instanceof 測(cè)試某個(gè)對(duì)象是否由某個(gè)指定的構(gòu)造器創(chuàng)建

     [1,2,3] instanceof Array //true
      "1" instanceof Array // false
   
   //比instanceof更可靠 Array.isArray

    Array.isArray([1,2,3]); //true

   //Object對(duì)象的toString()方法,可以返回所創(chuàng)建對(duì)象的內(nèi)部類名

    Object.prototype.toString.call([1,2,3]); //"[object Array]"

    Object.prototype.toString.call("a"); //"[object String]"
2.轉(zhuǎn)換方法
   const test = [1,2,3];

   test.toString(); //"1,2,3"

   test.valueOf(); //[1,2,3]

   //toLocaleString大部分為返回與toString相同的結(jié)果,區(qū)別之處在于會(huì)調(diào)用每一項(xiàng)的toLocaleString()方法
   test.toLocaleString([1,2,3]); //[1,2,3];

   const testStr = test.join("|"); //"1|2|3"
   testStr.split("|"); // [1,2,3];
3.棧方法(push和pop 尾部操作)
  const test = new Array();
  const count= test.push("a","b");
  //count為操作完后的數(shù)組長(zhǎng)度
  console.log(count); //2
  
  const count1 = test.push("c");
  console.log(count1); //3
  
  const item = test.pop();
  console.log(item); //"c"
  
4.隊(duì)列方法(shift和unshift 頭部操作)
   const test = [1,2,3];
   const item = test.shift();
   console.log(item); //1
   console.log(test); //[2,3];
   
5.重排序方法
  const test = [1,2,3];
  const test1 = test.reverse(); // [3,2,1]
  test1.sort(); //[1,2,3]
  
6.操作方法
    //concat會(huì)創(chuàng)建當(dāng)前數(shù)組的一個(gè)副本再進(jìn)行操作,不影響原數(shù)組
    const test = [1,2,3];
    const test1 = [1,2,3].concat([4,5]);
    
    console.log(test); //[1,2,3]
    console.log(test1); //[1,2,3,4,5]
    
    //slice接受一個(gè)或兩個(gè)參數(shù),返回起始和結(jié)束位置之間的項(xiàng)(但不包括最后位置的項(xiàng)),不影響原數(shù)組
    const test = [1,2,3,4];
    const test1 = test.slice(0); //[1,2,3,4]
    const test2 = test.slice(1,3); //[2,3]
    
    console.log(test); //[1,2,3,4] 原數(shù)組未改變
    
    //splice 可用作刪除、插入和替換,改變?cè)瓟?shù)組
    const test = [1,2,3,4,5];
    
    test.splice(1,2); //test為[1,4,5]
    
    test.splice(1,0,"a","b"); //test為[1,"a","b",2,3,,4,5]
    
    test.splice(2,1,"c"); //test為[1,2,"c",4,5]
7.位置方法
     const test = [1,2,3,4,5,4,3,2];
     test.indexOf(4); //3
     
     test.lastIndexOf(4); //5
     test.indexOf("4"); //-1  必須全相等(===)
8.循環(huán)方法

1.filter() 對(duì)數(shù)組的每一項(xiàng)允許給定函數(shù),返回該函數(shù)會(huì)返回true的項(xiàng)組成數(shù)組,不會(huì)改變?cè)瓟?shù)組

 const test = [1,2,3,4,5];
 const test1 = test.filter((item) => item > 3);
 
 console.log(test); //[1,2,3,4,5];
 console.log(test1); //[4,5];

2.map() 對(duì)數(shù)組的每一項(xiàng)執(zhí)行給定函數(shù),返回每次函數(shù)調(diào)用的結(jié)果組成的數(shù)組,不會(huì)改變?cè)瓟?shù)組

   const test = [{a:1,b:2},{a:3,b:4},{a:5,b:6}];
   const test1 = test.map((item) => item["a"]);
   
   console.log(test); //[{a:1,b:2},{a:3,b:4},{a:5,b:6}]
   console.log(test1); //[1,3,5]

3.forEach 對(duì)數(shù)組的每一項(xiàng)運(yùn)行給定函數(shù),沒(méi)有返回新數(shù)組,沒(méi)有返回值

         const test = [[1],[2]];
         test.forEach((item) => item.push(1));
         console.log(test); //[[1,1], [2,1]]     
9.其他的循環(huán)方法
1) 普通for循環(huán)(性能較好)
      const test = [1,2,3,4];
      for(let i=0,len=test.length;i
2) for in 以【任意】順序遍歷一個(gè)對(duì)象的可枚舉屬性,所以不太建議用來(lái)遍歷一個(gè)數(shù)組,原因如下。
for...in不應(yīng)該用于迭代一個(gè) Array,其中索引順序很重要。數(shù)組索引只是具有整數(shù)名稱的枚舉屬性,并且與通用對(duì)象屬性相同。不能保證for ... in將以任何特定的順序返回索引。for ... in循環(huán)語(yǔ)句將返回所有可枚舉屬性,包括非整數(shù)類型的名稱和繼承的那些,即它返回的除了數(shù)字索引外還有可能是你自定義的屬性名字。
       const person = {work:"coder",age:"24",sex: "female"};
       for(prop in person) {
            console.log(`Jchermy[${prop}]=${person[prop]}`);
        }
        //Jchermy[work]=coder
        //Jchermy[age]=24
        //Jchermy[sex]=female
3)for..of  
語(yǔ)句在可迭代的對(duì)象上創(chuàng)建了一個(gè)循環(huán)(包括Array, Map, Set, 參數(shù)對(duì)象( arguments) 等等),
對(duì)值的每一個(gè)獨(dú)特的屬性調(diào)用一個(gè)將被執(zhí)行的自定義的和語(yǔ)句掛鉤的迭代。
for..of 作為es6中引進(jìn)的循環(huán),主要是為了補(bǔ)全之前for循環(huán)中的以下不足 :     

forEach 不能 break 和 return;

for-in 它不僅遍歷數(shù)組中的元素,還會(huì)遍歷自定義的屬性,甚至原型鏈上的屬性都被訪問(wèn)到。而且,遍歷數(shù)組元素的順序可能是隨機(jī)的。

 而相比之下for...of可以做到:

與forEach 相比,可以正確響應(yīng) break, continue, return。

for-of 循環(huán)不僅支持?jǐn)?shù)組,還支持大多數(shù)類數(shù)組對(duì)象,例如 DOM nodelist 對(duì)象。

for-of 循環(huán)也支持字符串遍歷,它將字符串視為一系列 Unicode 字符來(lái)進(jìn)行遍歷。

for-of 也支持 Map 和 Set (兩者均為 ES6 中新增的類型)對(duì)象遍歷。

        let test = [3, 5, 7];
        test.foo = "hello";
        
        for (let i in test) {
           console.log(i); // "0", "1", "2", "foo"
        }
        
        for (let i of test) {
           console.log(i); // "3", "5", "7" // 注意這里沒(méi)有 hello
        }
從以上我們可以看出for..of和for...in的區(qū)別

1. for...in循環(huán)出的是key,for...of循環(huán)出的是value
2. 作用于數(shù)組的for-in循環(huán)除了遍歷數(shù)組元素以外,還會(huì)遍歷自定義屬性,比如例子中的foo屬性。for...of循環(huán)不會(huì)循環(huán)對(duì)象的key,只會(huì)循環(huán)出數(shù)組的value。  

4)do...while 語(yǔ)句一直重復(fù)直到指定的條件求值得到假(false)

        let i = 0;
        do {
          i += 1;
          console.log(i);
        } while (i < 5);
        //1
        //2
        //3
        //4
        //5

5) while只要指定的條件為真就會(huì)一直執(zhí)行它的語(yǔ)句塊

    let n = 0;
    let x = 0;
    while(n<3) {
       n++;
       x +=n;
       console.log(n,xhdf);
    }
    // 1 1
    // 2 3
    // 3 6
    
三、常用數(shù)組操作 1.數(shù)組亂序

將一個(gè)數(shù)組完全打亂,然后返回打亂后的數(shù)組。也稱為洗牌算法。

1) 利用Math.random()和sort()結(jié)合

   const test = [1,2,3,4];
   test.concat().sort(()=> Math.random() - 0.5); // [2, 4, 1, 3]
 

這個(gè)方法貌似可以實(shí)現(xiàn)我們要的結(jié)果,但是實(shí)際上它并不完全是隨機(jī)的,而是越大的數(shù)字出現(xiàn)在越后面的概率越大。具體原因可以看這篇文章數(shù)組的完全隨機(jī)排列

2) 遍歷原數(shù)組,然后隨機(jī)產(chǎn)生下標(biāo),將這個(gè)下標(biāo)的值push到新的數(shù)組中,并隨即刪除這值,注意不是用delete,那樣并不會(huì)改變數(shù)組的長(zhǎng)度,效率不高,使用splice較好.

       function shuffle(array) {
          let i,n=array.length,copy=[];
          while(n) {
             i = Math.floor(Math.random()*n--);//n--是先與Math.random相乘再減一
             copy.push(array.splice(i, 1)[0]);
          }
          return copy;
       }
       const test = [1,2,3,4,5];
       console.log(shuffle(test));  //[2, 5, 4, 3, 1]

3)Fisher–Yates shuffle 算法 隨機(jī)從數(shù)組中抽出一個(gè)元素,然后與最后個(gè)元素交換,相當(dāng)于把這個(gè)隨機(jī)抽取的元素放到了數(shù)組最后面去,表示它已經(jīng)是被隨機(jī)過(guò)了,同時(shí)被換走的那個(gè)元素跑到前面去了,會(huì)在后續(xù)的重復(fù)操作中被隨機(jī)掉。一輪操作過(guò)后,下一輪我們只在剩下的n-1個(gè)元素也就是數(shù)組的前n-1個(gè)元素中進(jìn)行相同的操作,直到進(jìn)行到第一個(gè)。

    function shuffle(array) {
        let i, n=array.length;
        while(n) {
          i = Math.floor(Math.random()*(n--));
          
          t = array[i]
          array[i] = array[n];
          array[n] = t;
          n--;
        }
        return array;
    }
    var test = [1,2,3,4];
    console.log(shuffle(test.concat()));//傳入數(shù)組的副本
    
2. 求斐波那契序列的某一項(xiàng)的值

ps:這一題的解法有很多種,以下僅列出幾種

1) 首先祭出最經(jīng)典的解法,利用遞歸求值。

     function fibonacci(n) {
         if(n==0 || n==1 ) {
            return n;
         }
         return fibonacci(n-1)+fibonacci(n-2);
     }
     const test = fibonacci(4); //3

這種方法的問(wèn)題是很多值會(huì)重新求值,效率很低,因此并不推薦。
2)利用ES6的解構(gòu)賦值

     const fibonacci =(n)=>{
        let a = 0;
        let b= 1;
        let i = 2;
        while(i++ <= n){
          [a, b] = [b, a+b]; //解構(gòu)賦值
        }
        return b;
     }
     fibonacci(4); //3

3) 尾遞歸優(yōu)化

遞歸非常耗內(nèi)存,因?yàn)樾枰瑫r(shí)保存成千上百個(gè)調(diào)用幀,很容易發(fā)生‘棧溢出’。但對(duì)于尾遞歸優(yōu)化來(lái)說(shuō),由于只存在一個(gè)調(diào)用幀,所以永遠(yuǎn)不會(huì)發(fā)生棧溢出。而尾遞歸的實(shí)現(xiàn),往往需要改寫遞歸函數(shù),確保最后一步只調(diào)用自身。做到這一點(diǎn)的方法,就是把所有用到的內(nèi)部變量改寫成函數(shù)的參數(shù).
     function fibonacci(n, n1=0, n2=1){
         if(n <=1) {
            return n2;
         }
     return fibonacci(n-1, n2, n1 + n2);  
    
     }
     fibonacci(6); //8

4)利用緩存值減少重復(fù)求值

   function fibonacci(){
     var cache = {
        0:0,
        1:1
     }
     return function _fibonacci(n) {
         return typeof cache[n] === "number" ?
         cache[n]:
         cache[n] = _fibonacci(n-1) + _fibonacci(n-2);
     }  
   }
   const f = fibonacci();
   f(9); //34
3.數(shù)組排序

1)最常用的利用sort()排序,僅適用于純數(shù)字?jǐn)?shù)組

  //升序
  function asc(arr){
    return arr.sort((a,b)=> {return a-b;})
  }
  asc([6,3,4,2]);//[2,3,4,6]

    //降序
  function desc(arr){
    return arr.sort((a,b)=> {return b-a;})
  }
  desc([4,3,2,5]); //[5, 4, 3, 2]

2)由對(duì)象組成的數(shù)組,支持根據(jù)對(duì)象的某個(gè)屬性排序

  const sortByProp = (name)=>{
    return (f, s) => {
      var a, b;
      if (typeof f === "object" && typeof s === "object" && f && s) {
         a = f[name];
         b = s[name];
         if(a === b) {
            return 0;
         } else {
            return a < b ? -1 :1;
         }  
     } else {
        throw new TypeError("數(shù)組必須由對(duì)象組成");
     }
  };
};
const test = [{age:27, name:"xiaomi"},{age:17, name:"amy"},{age: 24, name: "Jchermy"}];
test.sort(sortByProp("age")); //[{age:17, name:"amy"},{age: 24, name: "Jchermy"}, {age:27, name:"xiaomi"}];
4.數(shù)組去重

1)利用array_filter()

   function unique(arr){
     let uniqueArr = [];
     uniqueArr = arr.filter((item) =>{
        return uniqueArr.includes(item) ? "" : uniqueArr.push(item);
     })
     return uniqueArr;
   };
   unique([1,2,3,1,6,3,2,7]); //[1,2,3,6,7];

2)利用es6中的Map()

   function unique(arr) {
     const seen = new Map();
     return arr.filter((item) => !seen.has(item) && seen.set(item, 1));
   }
   unique([11,2,3,4,4,2,5]); //[11, 2, 3, 4, 5]

3)利用es6中的Set()

    function unique(arr){
       return [...new Set(arr)]; //將set結(jié)構(gòu)轉(zhuǎn)為數(shù)組
    }
   unique([1,2,2,3,7,3,8,5]); //[1, 2, 3, 7, 8, 5]  
5.數(shù)組去除空值
function filter_array(array) {    
  return array.filter(item=>item);   
}   

const test = [undefined,undefined,1,"","false",false,true,null,"null"];     
filter_array(test);  //[1, "false", true, "null"]
四.結(jié)語(yǔ)

呼,寫了好幾天的文章終于寫完啦,撒花~~

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

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

相關(guān)文章

  • 排序算法分析總結(jié)js實(shí)現(xiàn))

    摘要:本文對(duì)一些排序算法進(jìn)行了簡(jiǎn)單分析,并給出了的代碼實(shí)現(xiàn)。平均時(shí)間復(fù)雜度不好分析,它是冒泡排序是穩(wěn)定的排序算法。冒泡排序是原地排序算法原地排序指的是空間復(fù)雜度是的排序算法。歸并排序,會(huì)將數(shù)組從中間分成左右兩部分。 本文對(duì)一些排序算法進(jìn)行了簡(jiǎn)單分析,并給出了 javascript 的代碼實(shí)現(xiàn)。因?yàn)楸疚陌舜罅康呐判蛩惴ǎ苑治霾粫?huì)非常詳細(xì),適合有對(duì)排序算法有一定了解的同學(xué)。本文內(nèi)容其實(shí)不...

    liaoyg8023 評(píng)論0 收藏0
  • Java學(xué)習(xí)路線總結(jié),搬磚工逆襲Java架構(gòu)師(全網(wǎng)最強(qiáng))

    摘要:哪吒社區(qū)技能樹打卡打卡貼函數(shù)式接口簡(jiǎn)介領(lǐng)域優(yōu)質(zhì)創(chuàng)作者哪吒公眾號(hào)作者架構(gòu)師奮斗者掃描主頁(yè)左側(cè)二維碼,加入群聊,一起學(xué)習(xí)一起進(jìn)步歡迎點(diǎn)贊收藏留言前情提要無(wú)意間聽到領(lǐng)導(dǎo)們的談話,現(xiàn)在公司的現(xiàn)狀是碼農(nóng)太多,但能獨(dú)立帶隊(duì)的人太少,簡(jiǎn)而言之,不缺干 ? 哪吒社區(qū)Java技能樹打卡?【打卡貼 day2...

    Scorpion 評(píng)論0 收藏0
  • 手動(dòng)實(shí)現(xiàn)bind函數(shù)(MDN提供Polyfill方案解析)

    摘要:被調(diào)用時(shí),等參數(shù)將置于實(shí)參之前傳遞給被綁定的方法。它返回由指定的值和初始化參數(shù)改造的原函數(shù)拷貝。一個(gè)綁定函數(shù)也能使用操作符創(chuàng)建對(duì)象這種行為就像把原函數(shù)當(dāng)成構(gòu)造器。其實(shí)這個(gè)思路也是庫(kù)如何實(shí)現(xiàn)繼承的方法。他的函數(shù)如下最后一步是將的指回。 update: 2018-06-08 原文鏈接 為什么要自己去實(shí)現(xiàn)一個(gè)bind函數(shù)? bind()函數(shù)在 ECMA-262 第五版才被加入;它可能無(wú)法在所...

    idisfkj 評(píng)論0 收藏0
  • (轉(zhuǎn))JavaScrit常用數(shù)組算法總結(jié)

    摘要:原文地址不管是在面試中還是在筆試中,我們都會(huì)被經(jīng)常問(wèn)到關(guān)于數(shù)組的一些算法,比方說(shuō)數(shù)組去重?cái)?shù)組求交集數(shù)組擾亂等等。今天抽點(diǎn)時(shí)間把中的一些常用的數(shù)組算法做一下總結(jié),以方便大家面試筆試或者日常開發(fā)過(guò)程中用到。 原文地址:http://www.cnblogs.com/front-... 不管是在面試中還是在筆試中,我們都會(huì)被經(jīng)常問(wèn)到關(guān)于javascript數(shù)組的一些算法,比方說(shuō)數(shù)組去重、數(shù)組求...

    warnerwu 評(píng)論0 收藏0
  • task0002(一)- JavaScript數(shù)據(jù)類型語(yǔ)言基礎(chǔ)

    摘要:不過(guò)讓流行起來(lái)的原因應(yīng)該是是目前所有主流瀏覽器上唯一支持的腳本語(yǔ)言。經(jīng)過(guò)測(cè)試,數(shù)字字符串布爾日期可以直接賦值,修改不會(huì)產(chǎn)生影響。再考慮對(duì)象類型為或者的情況。對(duì)于結(jié)果聲明其類型。判斷對(duì)象的類型是還是,結(jié)果類型更改。 轉(zhuǎn)載自我的個(gè)人博客 歡迎大家批評(píng)指正 1. 第一個(gè)頁(yè)面交互 這里最需要學(xué)習(xí)的老師的代碼中,每一部分功能都由函數(shù)控制,沒(méi)有創(chuàng)建一個(gè)全部變量。且最后有一個(gè)函數(shù)來(lái)控制執(zhí)行代碼...

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

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

0條評(píng)論

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