我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript中constructor属性如何使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript中constructor属性如何使用

这篇文章给大家介绍JavaScript中constructor属性如何使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

constructor属性始终指向创建当前对象的构造函数。比如下面例子:

// 等价于 var foo = new Array(1, 56, 34, 12);  var arr = [1, 56, 34, 12];  console.log(arr.constructor === Array); // true  // 等价于 var foo = new Function();  var Foo = function() { };  console.log(Foo.constructor === Function); // true  // 由构造函数实例化一个obj对象  var obj = new Foo();  console.log(obj.constructor === Foo); // true   // 将上面两段代码合起来,就得到下面的结论  console.log(obj.constructor.constructor === Function); // true

但是当constructor遇到prototype时,有趣的事情就发生了。

我们知道每个函数都有一个默认的属性prototype,而这个prototype的constructor默认指向这个函数。如下例所示:

function Person(name) {      this.name = name;  };  Person.prototype.getName = function() {      return this.name;  };  var p = new Person("ZhangSan");   console.log(p.constructor === Person);  // true  console.log(Person.prototype.constructor === Person); // true  // 将上两行代码合并就得到如下结果  console.log(p.constructor.prototype.constructor === Person); // true

当时当我们重新定义函数的prototype时(注意:和上例的区别,这里不是修改而是覆盖),constructor属性的行为就有点奇怪了,如下示例:

function Person(name) {      this.name = name;  };  Person.prototype = {      getName: function() {          return this.name;      }  };  var p = new Person("ZhangSan");  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;      }  });

而constructor属性始终指向创建自身的构造函数,所以此时Person.prototype.constructor === Object,即是:

function Person(name) {      this.name = name;  };  Person.prototype = {      getName: function() {          return this.name;      }  };  var p = new Person("ZhangSan");  console.log(p.constructor === Object);  // true  console.log(Person.prototype.constructor === Object); // true  console.log(p.constructor.prototype.constructor === Object); // true

怎么修正这种问题呢?方法也很简单,重新覆盖Person.prototype.constructor即可:

function Person(name) {      this.name = name;  };  Person.prototype = new Object({      getName: function() {          return this.name;      }  });  Person.prototype.constructor = Person;  var p = new Person("ZhangSan");  console.log(p.constructor === Person);  // true  console.log(Person.prototype.constructor === Person); // true  console.log(p.constructor.prototype.constructor === Person); // true

关于JavaScript中constructor属性如何使用就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript中constructor属性如何使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

JavaScript Array constructor属性有什么用

JavaScript的Array构造函数属性是用于返回创建Array对象时使用的构造函数的引用。它有以下用途:1. 获取数组对象的构造函数:可以通过Array构造函数属性来获取用于创建数组对象的构造函数的引用。例如:```javascrip
2023-10-12

JavaScript如何使用constructor属性来确定变量是否是数组

这篇文章主要介绍了JavaScript如何使用constructor属性来确定变量是否是数组,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。使用对象的构造函数属性每个对象都有一
2023-06-17

PHP8中如何使用Constructor Property Promotion来简化类的属性声明?

PHP8是PHP编程语言的最新版本,引入了一项强大的特性,即Constructor Property Promotion(构造函数属性提升)。这个特性使得在类的构造函数中定义和初始化属性变得非常简单和优雅。本文将详细介绍Constructo
2023-10-22

vbs中如何使用Size属性

本篇文章为大家展示了vbs中如何使用Size属性,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Size 属性对于文件,返回指定文件的字节数;对于文件夹,返回该文件夹中所有文件和子文件夹的字节数。方便
2023-06-08

ASP.NET中Response.BufferOutput属性如何使用

本文小编为大家详细介绍“ASP.NET中Response.BufferOutput属性如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.NET中Response.BufferOutput属性如何使用”文章能帮助大家解决疑惑,下
2023-07-02

python中@Property属性如何使用

这篇文章主要介绍“python中@Property属性如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python中@Property属性如何使用”文章能帮助大家解决问题。一、前言本文介绍的属
2023-07-02

编程热搜

目录