首頁 > web前端 > js教程 > 主體

js如何實作原生map

王林
發布: 2020-03-26 10:12:30
轉載
2800 人瀏覽過

js如何實作原生map

js原生方法map實現,程式碼如下:

<!DOCTYPE html>
<html>

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <meta name="author" content="杨欣">
  <title>map</title>
</head>

<body>

  <script>
    Array.prototype.my_map = function (callback) {
      if (!Array.isArray(this) || !this.length || typeof callback !== &#39;function&#39;) {
        return []
      } else {
        let result = [];
        for (let index = 0; index < this.length; index++) {
          const element = this[index];
          result.push(callback(element, index, this))
        }
        return result
      }
    }

    let arr = [1, 2, 3, 4, 5]
    let res = arr.my_map((ele, i) => {
      return ele + 10
    })
    console.log(res)
  </script>
</body>

</html>
登入後複製

(推薦教學:js教學

#補充知識點:

我們平常用的是已經封裝好的map方法,如果讓我們自己封裝一個map,應該如何實作。

萬變不離其宗,其實遍歷陣列的核心還是for迴圈。因此下面封裝一個map方法。

想法如下:

1、在原型上加入一個方法

2、傳一個函數和this

3、 call 方法傳的參數和封裝好的map方法的參數是一樣的。

Array.prototype.fakeMap = function(fn,context) {
	let arr = this;
	let temp = [];
	for(let i=0;i<arr.length;i++){
		let result = fn.call(context,arr[i],i,arr);
		temp.push(result);
	}
	return temp;
}
登入後複製

推薦影片教學:javascript影片教學

#

以上是js如何實作原生map的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:jb51.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!