摘要:它不参与对象的构造,也就是说这个属性只是存储了构造函数的映像而已,没啥用。即它只是为了方便人查看构造函数而存在的所以说,当我们之后,最好再添加这样避免混淆。我们可以用判断对象和构造函数是否对应虽然上面那个是指向但是依然为。
在JS中,构造器(constructor)是用来用new关键词来创建对象的一个普普通通的函数,为了在形式上区别一般的函数,第一个字母通常大写。
function Person(){}; // constructor var wenzhe = new Person();
这就是基本的格式,我们能通过wenzhe.constructor或者Person.prototype.constructor来查看我们的构造函数,但是查看的这个构造函数只是表象。它不参与对象的构造,也就是说这个属性只是存储了构造函数的映像而已,没啥用。真正构造对象的那个构造函数永远是new后面那个。即它只是为了方便人查看构造函数而存在的
function Number() { this.name = "Number"; } function Two() {} function Three() { this.name = "Three" } Two.prototype = new Number(); Two.prototype.constructor === Number.prototype.constructor; // true Two.prototype.constructor = Three; var a = new Two(); a.name // shape; a.constructor // ..three...
所以说,当我们 Two.prototype = new Number()之后,最好再添加 Two.prototype.constructor = Two,这样避免混淆。
我们可以用 console.log(wenzhe instanceof Person) 判断对象和构造函数是否对应
,虽然上面那个a.constructor是指向Three,但是console.log(a instanceof Three) 依然为false。
还有一点就是 object literal 或者 Object constructor创建的对象的constructor指向Object
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/84381.html
摘要:然而事实上并不是。函数本身也是一个对象,但是给这个对象添加属性并不能影响。一图胜千言作者给出的解决方案,没有麻烦的,没有虚伪的,没有混淆视线的,原型链连接不再赤裸裸。所以是这样的一个函数以为构造函数,为原型。 注意:本文章是个人《You Don’t Know JS》的读书笔记。在看backbone源码的时候看到这么一小段,看上去很小,其实忽略了也没有太大理解的问题。但是不知道为什么,我...
摘要:是完全的面向对象语言,它们通过类的形式组织函数和变量,使之不能脱离对象存在。而在基于原型的面向对象方式中,对象则是依靠构造器利用原型构造出来的。 JavaScript 函数式脚本语言特性以及其看似随意的编写风格,导致长期以来人们对这一门语言的误解,即认为 JavaScript 不是一门面向对象的语言,或者只是部分具备一些面向对象的特征。本文将回归面向对象本意,从对语言感悟的角度阐述为什...
摘要:写在前面如果说是一本武学典籍,那么原型链就是九阳神功。那么,如何修炼好中的九阳神功呢真正的功法大成的技术是从底层上去理解,那种工程师和码农的区别就在于对底层的理解,当你写完一行代码,或者你遇见一个解决的速度取决于你对底层的理解。 写在前面 如果说JavaScript是一本武学典籍,那么原型链就是九阳神功。在金庸的武侠小说里面,对九阳神功是这样描述的:练成「九阳神功」后,会易筋洗髓;生出...
摘要:写在前面如果说是一本武学典籍,那么原型链就是九阳神功。那么,如何修炼好中的九阳神功呢真正的功法大成的技术是从底层上去理解,那种工程师和码农的区别就在于对底层的理解,当你写完一行代码,或者你遇见一个解决的速度取决于你对底层的理解。 写在前面 如果说JavaScript是一本武学典籍,那么原型链就是九阳神功。在金庸的武侠小说里面,对九阳神功是这样描述的:练成「九阳神功」后,会易筋洗髓;生出...
阅读 1095·2021-11-23 09:51
阅读 1058·2021-10-18 13:31
阅读 2938·2021-09-22 16:06
阅读 4232·2021-09-10 11:19
阅读 2182·2019-08-29 17:04
阅读 389·2019-08-29 10:55
阅读 2439·2019-08-26 16:37
阅读 3350·2019-08-26 13:29