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

資訊專欄INFORMATION COLUMN

《jacascript高級程序設(shè)計(jì)》筆記:數(shù)組方法高級

yanbingyun1990 / 730人閱讀

摘要:位置方法為數(shù)組實(shí)例添加了兩個位置方法和。參數(shù)要查找的項(xiàng)和可選的表示查找起點(diǎn)位置的索引。函數(shù)接受個參數(shù)之前值當(dāng)前值索引值以及數(shù)組本身。

這一章節(jié)主要記錄的是ES5的方法,在低版本瀏覽器上存在一定的兼容,但是主流手機(jī)上使用大可放心。

位置方法

ECMAScript 5 為數(shù)組實(shí)例添加了兩個位置方法:indexOf()和 lastIndexOf()。

1.參數(shù): 要查找的項(xiàng)和(可選的)表示查找起點(diǎn)位置的索引。
2.indexOf()方法從數(shù)組的開頭(位置0)開始向后查找,lastIndexOf()方法則從數(shù)組的末尾開始向前查找
3.兩個方法都返回要查找的項(xiàng)在數(shù)組中的位置,或者在沒找到的情況下返回-1。
4.在比較第一個參數(shù)與數(shù)組中的每一項(xiàng)時,會使用全等操作符

var numbers = [1,2,3,4,5,4,3,2,1];
alert(numbers.indexOf(4));        //3

alert(numbers.lastIndexOf(4)); //5
alert(numbers.indexOf(4, 4));     //5
alert(numbers.lastIndexOf(4, 4)); //3

var person = { name: "Nicholas" };
var people = [{ name: "Nicholas" }];
var morePeople = [person];
alert(people.indexOf(person));     //-1
alert(morePeople.indexOf(person)); //0
迭代方法

聲明:以下方法參數(shù)都是function類型,默認(rèn)有傳參,方法中的function回調(diào)支持3個參數(shù),第1個是遍歷的數(shù)組內(nèi)容;第2個是對應(yīng)的數(shù)組索引,第3個是數(shù)組本身

1.forEach()方法
【遍歷】遍歷數(shù)組,沒有返回值!沒有返回值!沒有返回值!重要的事情說三遍
forEach()方法幾乎可以代替for的用法,如果對數(shù)組的返回或跳出沒有要求

用法:

[1, 2 ,3, 4].forEach(function(value, index, arr){
    console.log(value); // 當(dāng)前值
    console.log(index); // 當(dāng)前索引
    console.log(arr); // 指向當(dāng)前數(shù)組
});

// 等同于
var array = [1, 2, 3, 4];
for (var k = 0, length = array.length; k < length; k++) {
    //...
}

用法雖然簡單,但在低版本的瀏覽器上存在兼容,下面提供一個兼容性的寫法:

// 對于古董瀏覽器,如IE6-IE8

if (typeof Array.prototype.forEach != "function") {
  Array.prototype.forEach = function (fn, context) {
    for (var k = 0, length = this.length; k < length; k++) {
      if (typeof fn === "function" && Object.prototype.hasOwnProperty.call(this, k)) {
        fn.call(context, this[k], k, this);
      }
    }
  };
}

2.map()方法

【映射】對數(shù)組中的每一項(xiàng)運(yùn)行給定函數(shù),返回每次函數(shù)調(diào)用的結(jié)果組成的數(shù)組,返回的數(shù)組長度一定與原數(shù)組長度相同,常用來改造某一數(shù)組,例如對某段數(shù)組進(jìn)行篩選或插入新的元素

基本用法:

// 含有return
[1, 2, 3, 4].map(function (item) {
  return item * item; // [1, 4, 9, 16]
});

// 不含return
[1, 2, 3, 4].map(function (item) {
  item * item; // [undefined, undefined, undefined, undefined]
});

用于篩選某一段數(shù)組,返回符合要求對元素組成的新數(shù)組:

var users = [
  {name: "佟麗婭", "email": "[email protected]"},
  {name: "趙麗穎",   "email": "[email protected]"},
  {name: "肉巴",  "email": "[email protected]"}
];

var emails = users.map(function (user) { return user.email; });
// ["[email protected]", "[email protected]", "[email protected]"]

用于插入新的元素:

var users = [
  {name: "佟麗婭", "email": "[email protected]"},
  {name: "趙麗穎",   "email": "[email protected]"},
  {name: "肉巴",  "email": "[email protected]"}
];
users.map(function(v){
    v.enName = v.email.slice(0, v.email.indexOf("@"));
    return v
})

兼容性寫法:

if (typeof Array.prototype.map != "function") {
  Array.prototype.map = function (fn, context) {
    var arr = [];
    if (typeof fn === "function") {
      for (var k = 0, length = this.length; k < length; k++) {      
         arr.push(fn.call(context, this[k], k, this));
      }
    }
    return arr;
  };
}

3.filter()方法

【篩選】對數(shù)組中的每一項(xiàng)運(yùn)行給定函數(shù),返回該函數(shù)會返回 true 的項(xiàng)組成的數(shù)組
與map()方法的用法較為相似,但是僅返回滿足要求的項(xiàng),返回的新的數(shù)組一定是原數(shù)組中的元素,且數(shù)組長度小于等于原數(shù)組長度

基本用法

[0, 1, 2, 3].filter(function(item) {
    return item; // [1, 2, 3]
});

var users = [
  {name: "佟麗婭", "email": "[email protected]", age: 24},
  {name: "趙麗穎",   "email": "[email protected]", age: 18},
  {name: "肉巴",  "email": "[email protected]", age: 17}
];
users.map(function(v){
    return v.age > 18// {name: "佟麗婭", email: "[email protected]", age: 24}
})

兼容性寫法:

if (typeof Array.prototype.filter != "function") {
  Array.prototype.filter = function (fn, context) {
    var arr = [];
    if (typeof fn === "function") {
       for (var k = 0, length = this.length; k < length; k++) {
          fn.call(context, this[k], k, this) && arr.push(this[k]);
       }
    }
    return arr;
  };
}

every()方法

【全滿足返回true】對數(shù)組中的每一項(xiàng)運(yùn)行給定函數(shù),如果該函數(shù)對每一項(xiàng)都返回 true,則返回 true

基本用法:

// 數(shù)組中所有項(xiàng)滿足要求時返回true,否則為false
[1,2,3,4,5,6,7].every(function(v){
    return v > 2; // false
})

兼容性寫法:

if (typeof Array.prototype.every != "function") {
  Array.prototype.every = function (fn, context) {
    var passed = true;
    if (typeof fn === "function") {
       for (var k = 0, length = this.length; k < length; k++) {
          if (passed === false) break;
          passed = !!fn.call(context, this[k], k, this);
      }
    }
    return passed;
  };
}

some()方法

【某項(xiàng)滿足返回true】對數(shù)組中的每一項(xiàng)運(yùn)行給定函數(shù),如果該函數(shù)對任一項(xiàng)返回 true,則返回 true

基本寫法

// 數(shù)組中某一項(xiàng)滿足要求時返回true,否則為false
[1,2,3,4,5,6,7].some(function(v){
    return v > 2; // true
})

兼容性寫法:

if (typeof Array.prototype.some != "function") {
  Array.prototype.some = function (fn, context) {
    var passed = false;
    if (typeof fn === "function") {
         for (var k = 0, length = this.length; k < length; k++) {
          if (passed === true) break;
          passed = !!fn.call(context, this[k], k, this);
      }
    }
    return passed;
  };
}
歸并方法

歸并方法包括reduce()和reduceRight()兩種,寫法同上面的方式相似。函數(shù)接受4個參數(shù):之前值、當(dāng)前值、索引值以及數(shù)組本身。initialValue參數(shù)可選,表示初始值。若指定,則當(dāng)作最初使用的previous值;如果缺省,則使用數(shù)組的第一個元素作為previous初始值,同時current往后排一位,相比有initialValue值少一次迭代

1.reduce()方法

基本用法:

var sum = [1, 2, 3, 4].reduce(function (previous, current, index, array) {
  return previous + current;
});

console.log(sum); // 10

// 執(zhí)行過程
// 初始設(shè)置
previous = initialValue = 1, current = 2
// 第一次迭代
previous = (1 + 2) =  3, current = 3
// 第二次迭代
previous = (3 + 3) =  6, current = 4
// 第三次迭代
previous = (6 + 4) =  10, current = undefined (退出)
var sum = [1, 2, 3, 4].reduce(function (previous, current, index, array) {
  return previous + current;
}, 10);

console.log(sum); // 20
// 執(zhí)行過程
// 初始設(shè)置
initialValue = 10, previous = 1, current = 2
// 第一次迭代
previous = (10 + 1) =  11, current = 2
// 第二次迭代
previous = (11 + 2) =  13, current = 3
// 第三次迭代
previous = (13 + 3) =  16, current = 4
// 第四次迭代
previous = (16 + 4) =  20, current = undefined

數(shù)組扁平化

var matrix = [
  [1, 2],
  [3, 4],
  [5, 6]
];

// 二維數(shù)組扁平化
var flatten = matrix.reduce(function (previous, current) {
  return previous.concat(current);
});

console.log(flatten); // [1, 2, 3, 4, 5, 6]

兼容寫法:

if (typeof Array.prototype.reduce != "function") {
  Array.prototype.reduce = function (callback, initialValue ) {
     var previous = initialValue, k = 0, length = this.length;
     if (typeof initialValue === "undefined") {
        previous = this[0];
        k = 1;
     }
     
    if (typeof callback === "function") {
      for (k; k < length; k++) {
         this.hasOwnProperty(k) && (previous = callback(previous, this[k], k, this));
      }
    }
    return previous;
  };
}

2.reduceRight()方法

與reduce()方法相同,只是執(zhí)行順序是從右往左

兼容性寫法:

if (typeof Array.prototype.reduceRight != "function") {
  Array.prototype.reduceRight = function (callback, initialValue ) {
    var length = this.length, k = length - 1, previous = initialValue;
    if (typeof initialValue === "undefined") {
        previous = this[length - 1];
        k--;
    }
    if (typeof callback === "function") {
       for (k; k > -1; k-=1) {          
          this.hasOwnProperty(k) && (previous = callback(previous, this[k], k, this));
       }
    }
    return previous;
  };
}

參考:ES5中新增的Array方法詳細(xì)說明

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

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

相關(guān)文章

  • 《javascript高級程序設(shè)計(jì)筆記:檢測數(shù)組方法

    摘要:如果網(wǎng)頁中包含多個框架,那實(shí)際上就存在兩個以上不同的全局執(zhí)行環(huán)境,從而存在兩個以上不同版本的構(gòu)造函數(shù)。如果你從一個框架向另一個框架傳入一個數(shù)組,那么傳入的數(shù)組與在第二個框架中原生創(chuàng)建的數(shù)組分別具有各自不同的構(gòu)造函數(shù)。 如何檢測某個變量是否為數(shù)組? 《javascript 高級程序設(shè)計(jì)》原文摘錄: 自從 ECMAScript 3 做出規(guī)定以后,就出現(xiàn)了確定某個對象是不是數(shù)組的經(jīng)典問題...

    wums 評論0 收藏0
  • JavaScript高級程序設(shè)計(jì)-摘要筆記-1

    摘要:說明此摘要筆記系列是我最近看高級程序設(shè)計(jì)第版隨手所記。摘要筆記本身沒有系統(tǒng)性,沒有全面性可言,寫在這里供有一定基礎(chǔ)的前端開發(fā)者參考交流。對每一項(xiàng)運(yùn)行給定函數(shù),返回該函數(shù)會返回的項(xiàng)組成的數(shù)組。是的反操作是的反操作第一部分結(jié)束。 說明: 此摘要筆記系列是我最近看《JavaScript高級程序設(shè)計(jì)(第3版)》隨手所記。 里面分條列舉了一些我認(rèn)為重要的、需要記下的、對我有幫助的點(diǎn),是按照我看...

    chavesgu 評論0 收藏0
  • 讀書筆記(01) - JSON - JavaScript高級程序設(shè)計(jì)

    摘要:用于把對象序列化字符串,在序列化對象時,所有函數(shù)及原型成員都會被有意忽略,不體現(xiàn)在結(jié)果中。對第步返回的每個值進(jìn)行相應(yīng)的序列化。參考文檔高級程序設(shè)計(jì)作者以樂之名本文原創(chuàng),有不當(dāng)?shù)牡胤綒g迎指出。 showImg(https://segmentfault.com/img/bVburW1?w=658&h=494); JSON與JavaScript對象 JSON是一種表示結(jié)構(gòu)化數(shù)據(jù)的存儲格式,語...

    mengbo 評論0 收藏0
  • 《JavaScript高級程序設(shè)計(jì)》讀書筆記

    摘要:為了每個對象都能通過來檢測,需要以或者的形式來調(diào)用,傳遞要檢查的對象作為第一個參數(shù),稱為。對象都是動態(tài)的,這就意味著每次訪問對象,都會運(yùn)行一次查詢。是語言中立的用于訪問和操作和文檔。 一、第三章 基本概念: 1.理解參數(shù) 1.1 可以向函數(shù)中傳遞任意數(shù)量的參數(shù),并且可以通過arguments對象來訪問這些參數(shù)。 1.2 arguments對象只是類似數(shù)組,它通過length來確定傳進(jìn)來...

    dayday_up 評論0 收藏0
  • 《javascript高級程序設(shè)計(jì)筆記:正則表達(dá)式

    摘要:布爾值,表示是否設(shè)置了標(biāo)志。正則表達(dá)式的字符串表示,按照字面量形式而非傳入構(gòu)造函數(shù)中的字符串模式返回正則表達(dá)式的實(shí)例方法方法是否匹配基本語法參數(shù)為正則表達(dá)式為所要匹配的字符串返回值布爾值在模式與該參數(shù)匹配的情況下返回否則,返回。 高程書中對正則部分介紹的偏少,特別是元字符部分幾乎沒有介紹;我找了幾篇不錯的博客作為收錄:正則表達(dá)式30分鐘入門教程正則表達(dá)式-理論基礎(chǔ)篇正則表達(dá)式-基礎(chǔ)實(shí)戰(zhàn)...

    ingood 評論0 收藏0

發(fā)表評論

0條評論

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