自定義ES6提供的數(shù)組方法(forEach涕滋、filter、map挠阁、some宾肺、every、find侵俗、findIndex)

原理部分

JavaScript 在ES6版本后提供了一些更加便捷的方法供開發(fā)者使用锨用,實(shí)現(xiàn)原理其實(shí)是在對(duì)應(yīng)的構(gòu)造函數(shù)原型提供方法。然后供開發(fā)者使用隘谣。接下來讓我們自定義這些ES6提供的簡(jiǎn)易函數(shù)吧增拥。

方法的實(shí)現(xiàn)原理

ES6提供的一些方法,底層主要是用for循環(huán)實(shí)現(xiàn)的寻歧,咱們?cè)谑褂眠^程中也主要是傳遞callback來控制輸出結(jié)果跪者。后邊的實(shí)現(xiàn)也主要是下邊的結(jié)構(gòu)。

Array.prototype.xxx = function (callback) {
    if (callback && typeof (callback) === 'function') {
        for (let i = 0; i < this.length; i++) {
            callback(this[i], i, this)
            // 通過這個(gè)callback 控制結(jié)果
        }
    }
}

代碼實(shí)現(xiàn)

// 案例數(shù)據(jù)
var arr = [
    {
        name: "張三",
        id: 1
    },
    {
        name: "李四",
        id: 2
    },
    {
        name: "王麻子",
        id: -1
    }
]

forEach(數(shù)組每個(gè)元素都執(zhí)行一次回調(diào)函數(shù))

Array.prototype.forEach = function (callback) {
    if (callback && typeof (callback) === 'function') {
        for (let i = 0; i < this.length; i++) {
            callback(this[i], i, this)
        }
    }
}

filter(檢測(cè)數(shù)值元素熄求,并返回符合條件所有元素的數(shù)組)

Array.prototype.filter = function (callback) {
    let temp = []
    if (callback && typeof (callback) === 'function') {
        for (let i = 0; i < this.length; i++) {
            if (callback(this[i], i, this)) {
                temp.push(this[i])
            }
        }
    }
    return temp
}

map(通過指定函數(shù)處理數(shù)組的每個(gè)元素渣玲,并返回處理后的數(shù)組)

Array.prototype.map = function (callback) {
    let temp = []
    if (callback && typeof (callback) === 'function') {
        for (let i = 0; i < this.length; i++) {
            temp.push(callback(this[i], i, this))
        }
    }
    return temp
}

some(檢測(cè)數(shù)組元素中是否有元素符合指定條件)

Array.prototype.some = function (callback) {
    let temp = false;
    if (callback && typeof (callback) === 'function') {
        for (let i = 0; i < this.length; i++) {
            if (callback(this[i], i, this)) {
                temp = true
                break
            }
        }
    }
    return temp
}

every(檢測(cè)數(shù)值元素的每個(gè)元素是否都符合條件)

Array.prototype.every = function (callback) {
    let temp;
    if (callback && typeof (callback) === 'function') {
        for (let i = 0; i < this.length; i++) {
            if (!callback(this[i], i, this)) {
                temp = false
                break
            } else {
                temp = true
            }
        }
    }
    return temp
}

find (返回符合傳入測(cè)試(函數(shù))條件的數(shù)組元素)

Array.prototype.find = function (callback) {
    let temp;
    if (callback && typeof (callback) === 'function') {
        for (let i = 0; i < this.length; i++) {
            if (callback(this[i], i, this)) {
                temp = this[i]
                break
            }
        }
    }
    return temp
}

findIndex(返回符合傳入測(cè)試(函數(shù))條件的數(shù)組元素索引)

Array.prototype.findIndex = function (callback) {
    let temp;
    if (callback && typeof (callback) === 'function') {
        for (let i = 0; i < this.length; i++) {
            if (callback(this[i], i, this)) {
                temp = i
                break
            }
        }
    }
    return temp
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市弟晚,隨后出現(xiàn)的幾起案子忘衍,更是在濱河造成了極大的恐慌,老刑警劉巖卿城,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件枚钓,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡瑟押,警方通過查閱死者的電腦和手機(jī)搀捷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來多望,“玉大人嫩舟,你說我怎么就攤上這事』惩担” “怎么了家厌?”我有些...
    開封第一講書人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)椎工。 經(jīng)常有香客問我饭于,道長(zhǎng)蜀踏,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任掰吕,我火速辦了婚禮果覆,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘殖熟。我一直安慰自己随静,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開白布吗讶。 她就那樣靜靜地躺著燎猛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪照皆。 梳的紋絲不亂的頭發(fā)上重绷,一...
    開封第一講書人閱讀 49,749評(píng)論 1 289
  • 那天,我揣著相機(jī)與錄音膜毁,去河邊找鬼昭卓。 笑死,一個(gè)胖子當(dāng)著我的面吹牛瘟滨,可吹牛的內(nèi)容都是我干的候醒。 我是一名探鬼主播,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼杂瘸,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼倒淫!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起败玉,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤敌土,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后运翼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體返干,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年血淌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了矩欠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡悠夯,死狀恐怖癌淮,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情疗疟,我是刑警寧澤该默,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布瞳氓,位于F島的核電站策彤,受9級(jí)特大地震影響栓袖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜店诗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一裹刮、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧庞瘸,春花似錦捧弃、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至瞬场,卻和暖如春买鸽,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背贯被。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來泰國(guó)打工眼五, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人彤灶。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓看幼,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親幌陕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子诵姜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容