浅谈javascript中的constructor_基础知识
程序员文章站
2022-05-18 19:45:22
...
下面我就为大家带来一篇浅谈javascript中的constructor。现在就分享给大家,也给大家做个参考。
constructor,构造函数,对这个名字,我们都不陌生,constructor始终指向创建当前对象的构造函数。
这里有一点需要注意的是,每个函数都有一个prototype属性,这个prototype的constructor指向这个函数,这个时候我们修改这个函数的prototype时,就发生了意外。如
function Person(name,age){ this.name = name; this.age = age; } Person.prototype.getAge = function(){ return this.age; } Person.prototype.getName = function(){ return this.name; } var p = new Person("Nicholas",18); console.log(p.constructor); //Person(name, age) console.log(p.getAge()); //18 console.log(p.getName()); //Nicholas
但是如果是这样:
function Person(name,age){ this.name = name; this.age = age; } Person.prototype = { getName:function(){ return this.name; }, getAge:function(){ return this.age; } } var p = new Person("Nicholas",18); console.log(p.constructor); //Object() console.log(p.getAge()); //18 console.log(p.getName()); //Nicholas
结果constructor变了。
原因就是prototype本身也是对象,上面的代码等价于
Person.prototype = new Object({ getName:function(){ return this.name; }, getAge:function(){ return this.age; } });
因为constructor始终指向创建当前对象的构造函数,那么就不难理解上面代码p.constructor输出的是Object了。
对于修改了prototype之后的constructor还想让它指向Person怎么办呢?简单,直接给Person.prototype.constructor赋值就可以了:
Person.prototype = { constructor:Person, getName:function(){ return this.name; }, getAge:function(){ return this.age; } }
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
关于JavaScript Array(数组) 对象的使用方法
以上就是浅谈javascript中的constructor_基础知识的详细内容,更多请关注其它相关文章!
上一篇: PHP冒泡算法详解(递归实现)
下一篇: PHP之PDO介绍
推荐阅读
-
浅谈Python中列表生成式和生成器的区别
-
浅谈SpringBoot 中关于自定义异常处理的套路
-
JavaScript之函数中的this和严格模式
-
浅谈c#.net中巧用ToString()将日期转成想要的格式
-
浅谈mysql数据库中的换行符与textarea中的换行符
-
浅谈python中scipy.misc.logsumexp函数的运用场景
-
浅谈MySQL中group_concat()函数的排序方法
-
浅谈three.js中的needsUpdate的应用
-
关于Javascript中document.cookie的使用
-
JavaScript中的 attribute 和 jQuery中的 attr 方法浅析