• 手机版

    扫码体验手机版

  • 微信公众号

    扫码关注公众号

国内首家协议开发

软芯音视解码保护平台

在线
客服

发布
需求

在线
聊天

天盟
APP

天盟APP下载

关注
微信

微信扫一扫访问
顶部

js prototype的问题

原文:
当时当我们重新定义函数的prototype时(注意:和上例的区别,这里不是修改而是覆盖), constructor的行为就有点奇怪了,如下示例:
function Person(name) {            this.name = name;        };        Person.prototype = {            getName: function() {                return this.name;            }        };        var p = new Person("haorooms");        console.log(p.constructor === Person);  // false        console.log(Person.prototype.constructor === Person); // false        console.log(p.constructor.prototype.constructor === Person); // false为什么呢? 原来是因为覆盖Person.prototype时,等价于进行如下代码操作:
Person.prototype = new Object({            getName: function() {                return this.name;            }        });-------------------------------------------------------------分割线----------------------------------------------------
问题1.为什么重新定义prototype后
p.constructor === Person都会返回false
问题2.
Person.prototype = new Object({            getName: function() {                return this.name;            }        });没看懂什么意思,为什么要在写参数的位置定义属性方法呢

免责声明:本内容仅代表回答会员见解不代表天盟观点,请谨慎对待。

版权声明:作者保留权利,不代表天盟立场。

使用道具 举报

发新帖

发布任务需求已有1031167位用户正在使用天盟网服务

发布分类: *
任务预算: *
需求内容: *
手机号码: *
任务商家报价为
  • 预算价 :
  • 成交价 :
  • 完工期 :
  • 质保期 :

* 最终任务项目以服务商报价、双方协商为准!