zoukankan      html  css  js  c++  java
  • 关于prototype和__proto__,最好的一些解释

    更原理性的东西

    https://www.cnblogs.com/jyybeam/p/13200403.html

    以下是简单的理解

    prototype是函数特有的属性,是Function的静态属性;__proto__是对象特有的属性。

    因为函数本身是一种对象,所以函数既有prototype属性也有__proto__属性。

    当函数使用prototype属性时,是作为构造函数使用;

    当函数使用__proto__属性时,是作为一个对象使用。

    另外,__proto__属性内部属性,尽量不要使用。可以用setPrototypeOf()和getPrototypeOf()代替。

    1)普通函数分别取值

        function C() {}
        console.log(C.prototype);
        /*{ constructor: function C(){},__proto__: Object }*/
        // 使用__proto__时,是普通函数对象,原型对象指向Funtion的prototype属性
        console.log(C.__proto__ === Function.prototype);
    

    对于普通函数来说,prototype属性和__proto__属性都是可读写属性。

    给prototype赋值,会改变函数的原型对象和上面的构造函数。

        function C() {}
        function D() {}
        C.prototype = new D();
        console.log(Object.getOwnPropertyDescriptor(C, 'prototype'));
        /*
        {value: D, writable: true, enumerable: false, configurable: false} //可写
        */
        console.log(C.prototype.constructor === D); // true
    

    2)class类分别取值,和普通函数一样

      class A{}
      console.log(A.prototype);
      // {constructor: ƒ, __proto__: Object}
      console.log(A.__proto__ === Function.prototype);// true
    

    但是,在class中,prototype属性是只读的

      class A{}
      class B{
        add(){console.log('add')}
        static add(){console.log('static add')}
      }
      const a = new A();
      const b= new B();
      console.log(Object.getOwnPropertyDescriptor(A, 'prototype'));
      // {value: {…}, writable: false, enumerable: false, configurable: false}; // 只读
      A.__proto__ = B; // 静态属性方法继承
      b.add(); // add
      // a.add(); ❌ 不存在
      A.add(); // static add
      A.prototype.__proto__ = B.prototype; // 实例属性方法继承
      a.add(); // add
    
  • 相关阅读:
    [golang]text/template模板
    [golang]Go内嵌静态资源go-bindata的安装及使用
    GoCN每日新闻(2019-09-23)
    spring mvc中获取请求URL
    HBuilder搭配逍遥Android模拟器进行开发
    python 数据结构
    JDK8+Tomcat8配置https【转】
    JFinal的使用
    RESTful API 设计指南【转】
    jQuery验证控件jquery.validate.js的使用介绍
  • 原文地址:https://www.cnblogs.com/cn-oldboy/p/13376259.html
Copyright © 2011-2022 走看看