Heim >Web-Frontend >js-Tutorial >Defekte Threads, Prototypen und Prototypketten in JavaScript

Defekte Threads, Prototypen und Prototypketten in JavaScript

灭绝师太
灭绝师太Original
2021-11-04 11:43:291466Durchsuche

Defekte Threads, Prototypen und Prototypketten in JavaScript

Die Beziehung zwischen Prototyp und Prototypenkette verläuft durch die Objekte in JavaScript, und alles in JavaScript ist ein Objekt, daher sind Prototyp und Prototypenkette relativ wichtige Konzepte. Bringen wir es heute mit. Werfen wir einen Blick auf den Prototyp und die Prototypenkette in JavaScript. JavaScript中的对象,而JavaScript中万物皆对象,所以原型和原型链是比较重要的概念,今天就带大家一起来看一看JavaScript中的原型与原型链。

一、了解概念(知道有这两个名词即可)

  1. 原型(<em>prototype</em>

  2. 原型链(__<em>proto__</em>

二、了解从属关系

prototype  => 函数的一个属性         : 同时也是一个 对象{} (称之为原型对象亦可)

__proto__ => 对象Object的一个属性   : 同时也是一个 对象{}   (__proto__也就是[[Prototype]])

注:对象的__proto__保存着该对象的构造函数的prototype

    a.声明一个构造函数

    function Test() { }
  
    //prototype 是函数的一个属性
    console.dir(Test);
    console.log(Test.prototype);
    // Test.prototype也是一个对象
    console.log(typeof Test.prototype);

    b.声明一个对象

    const test = new Test();
    
    console.log(test);
    //验证test为一个对象
    console.log(typeof test);
    //__proto__是对象的一个属性
    console.log(test.__proto__);
    console.log(Test.prototype);
    //对象的__proto__属性存储着Test.prototype
    console.log(test.__proto__ === Test.prototype);
    // test.__proto__也是一个对象
    console.log(typeof test.__proto__);
function Test() {}
console.log(Test.prototype); //验证函数是否有prototype属性

let test = new Test();
console.dir(test.__proto__); //验证对象是否有__proto__属性
console.log(test.__proto__ === Test.prototype);//验证对象的__ptoto__是否保存着该对象的构造函数的prototype

console.log(Test.prototype.__proto__ === Object.prototype);//Test.prototype(是一个对象)的__proto__属性是否是对象的原型属性
console.log(Object.prototype.__proto__);//原型链的顶层没有__proto__属性 null

三、深入认识原型链、原型和原型继承

    function Test(){}
    let test =new Test();
    test.a= 10;
    //test.__proto__ === test.constructor.prototype
    test.__proto__.b1=11;//对象的__proto__属性存储着对象构造函数的prototype属性
    Test.prototype.b2=11;
   
    test.__proto__.__proto__.c1=12;
    Object.prototype.c2=12;
    console.log(test);
    console.log(Test.prototype);
    console.log(Object.prototype.__proto__);
   
    /*逐层解析
    * test{
    *        a = 10
    *        __proto__:Test.prototype{
    *                 b = 11
    *                 __proto__:Object.prototype{
    *                           c = 12
    *                           X__prototype__:null
    *                 }         
    *        }
    *     }
    *
    * */

四、总结

  • 不建议直接用 __proto__ 访问。

  • 可以简单概括为以<span style="color: rgb(0, 0, 0);">prototype</span>为原型节点, <span style="color: rgb(0, 0, 0);">__proto__</span>为原型链条。

  • 每个实例对象(<span style="color: rgb(0, 0, 0);">object</span>)都有一个私有属性(称之为 <span style="color: rgb(0, 0, 0);">__proto__</span> )指向它的构造函数的原型对象(<span style="color: rgb(0, 0, 0);">prototype</span>)。该原型对象也有一个自己的原型对象(<span style="color: rgb(0, 0, 0);">__proto__</span>),层层向上直到一个对象的原型对象为 <span style="color: rgb(0, 0, 0);">null</span>。根据定义,<span style="color: rgb(0, 0, 0);">null</span> 没有原型,并作为这个原型链中的最后一个环节。

  •  <span style="color: rgb(0, 0, 0);">someObject.[[Prototype]]</span> 符号是用于指向 <span style="color: rgb(0, 0, 0);">someObject</span> 的原型,<span style="color: rgb(0, 0, 0);">someObject.[[Prototype]]</span> === <span style="color: rgb(0, 0, 0);">__proto__</span>(JavaScript的非标准但许多浏览器实现的属性)。

  • <span style="color: rgb(0, 0, 0);">Object.prototype</span> 属性表示 <span style="color: rgb(0, 0, 0);">Object</span> 的原型对象。

  •  被构造函数创建的实例对象的 <span style="color: rgb(0, 0, 0);">[[Prototype]]</span> 指向 <span style="color: rgb(0, 0, 0);">func</span><span style="color: rgb(0, 0, 0);">prototype</span>

    1. Verstehen Sie die Konzepte (kennen Sie einfach diese beiden Begriffe)
  1. Prototyp (<em>Prototyp</em>)

  2. Prototypkette (__<em>proto__</em>)

2. Zugehörigkeiten verstehen🎜rrreee🎜Hinweis: Das __proto__ des Objekts speichert den Prototyp des Konstruktors des Objekts🎜🎜 a . Deklarieren Sie einen Konstruktor
🎜rrreee🎜 B. Tiefes Verständnis der Prototypenkette, des Prototyps und der Prototypenvererbung🎜rrreee🎜4 />🎜
  • 🎜Es wird nicht empfohlen, __proto__ Zugriff. 🎜🎜
  • 🎜 kann einfach so zusammengefasst werden, dass <span style="color: rgb(0, 0, 0);">prototype</span> als Prototypknoten verwendet wird <span style="color: rgb(0, 0, 0);">__proto__</span> ist die Prototypenkette. 🎜🎜
  • 🎜Jedes Instanzobjekt (<span style="color: rgb(0, 0, 0);">object</span>) hat eine private Eigenschaft (genannt For <span style="color: rgb(0, 0, 0);">__proto__</span> ) zeigt auf das Prototypobjekt seines Konstruktors (<span style="color : rgb( 0, 0, 0);">Prototyp</span>). Das Prototypobjekt verfügt auch über ein eigenes Prototypobjekt (<span style="color: rgb(0, 0, 0);">__proto__</span>), bis hin zum Prototyp eines Objekt Das Objekt ist <span style="color: rgb(0, 0, 0);">null</span>. Per Definition hat <span style="color: rgb(0, 0, 0);">null</span> keinen Prototyp und dient als letztes Glied in dieser Prototypenkette. 🎜🎜
  • 🎜 <span style="color: rgb(0, 0, 0);">someObject.[[Prototyp ]]</span>-Symbol wird verwendet, um auf <span style="color: rgb(0, 0, 0);">someObject</span> zu verweisen Prototype,<span style="color: rgb(0, 0, 0);">someObject.[[Prototype]]</span> === <span style="color: rgb(0, 0, 0);">__proto__</span>(JavaScript ist nicht standardmäßig, aber viele browserimplementierte Eigenschaften). 🎜🎜
  • 🎜<span style="color: rgb(0, 0, 0);">Object.prototype</span> -Attribut stellt das Prototypobjekt von <span style="color: rgb(0, 0, 0);">Object</span> dar. 🎜🎜
  • 🎜 Der <span style="color: rgb(0, 0, 0);">[[Prototype]]</span> des vom Konstruktor erstellten Instanzobjekts zu<span style="color: rgb(0, 0, 0);">func</span>s<span style="color: rgb(0, 0, 0). );">Prototyp</span>-Attribut. 🎜🎜🎜🎜Empfohlene Videos: 🎜 „Schnelle Einführung in JavaScript_Jade Girl Heart Sutra Series“🎜, 🎜 „Dugu Jiujian (6)_jQuery Video Tutorial“🎜🎜

Das obige ist der detaillierte Inhalt vonDefekte Threads, Prototypen und Prototypketten in JavaScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn