Heim  >  Artikel  >  Web-Frontend  >  So implementieren Sie eine native Karte in js

So implementieren Sie eine native Karte in js

王林
王林nach vorne
2020-03-26 10:12:302792Durchsuche

So implementieren Sie eine native Karte in js

JS native Method Map-Implementierung, der Code lautet wie folgt:

<!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>

(Empfohlenes Tutorial: js-Tutorial)

Ergänzende Wissenspunkte:

Wir verwenden normalerweise die Methode der gekapselten Karte. Wenn wir eine Karte selbst kapseln, wie sollten wir sie implementieren?

Das gleiche Prinzip bleibt bestehen. Tatsächlich ist der Kern des Durchlaufens eines Arrays die for-Schleife. Daher wird unten eine Kartenmethode gekapselt.

Die Idee ist wie folgt:

1. Fügen Sie eine Methode zum Prototyp hinzu

2. Übergeben Sie eine Funktion und dies

3. Die von der Aufrufmethode übergebenen Parameter sind dieselben wie die der gekapselten Kartenmethode.

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;
}

Empfohlenes Video-Tutorial: Javascript-Video-Tutorial

Das obige ist der detaillierte Inhalt vonSo implementieren Sie eine native Karte in js. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:jb51.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen