• 1.摘要
  • 2.基本信息
  • 3.简介
  • 4.解析
  • 4.1.说明
  • 4.2.语法
  • 4.3.返回值
  • 4.4.示例&说明
  • 5.参考资料

Constructor

构造函数(Constructor)在对象创建或者实例化时候被调用的方法。通常使用该方法来初始化数据成员和所需资源。构造器Constructor在js不能被继承,因此不能重写Overriding,但可以被重载Overloading

构造函数在C++中如果写成public属性那么可以继承

基本信息

  • 中文名称

    Constructor

  • 目的

    初始化数据成员和所需资源

  • 特点

    不能重写Overriding

  • 意义

    构造函数

简介

构造函数,是一种特殊的函数,主要用来在创建对象时初始化对象,即为对象成员变量赋初始值。总与new运算符一起使用在创建对象的语句中,特别的一个类可以有多个构造函数,可根据其参数个数的不同或参数类型的不同来区分它们,即构造函数的重载。

解析

说明

JavaScript中的constructor

对象的constructor1属性用于返回创建该对象的函数,也就是我们常说的构造函数1

在JavaScript中,每个具有原型的对象都会自动获得constructor属性。除了arguments、Enumerator、Error、Global、Math、RegExp、Regular Expression等一些特殊对象之外,其他所有的JavaScript内置对象都具备constructor属性。例如:Array、Boolean、Date、Function、Number、Object、String等。所有主流浏览器均支持该属性

浏览器支持

所有主要浏览器都支持constructor属性。2

c++

构造函数无返回值

语法

object.constructor (js)classname() //c++

返回值

js对象的constructor属性返回创建该对象的函数的引用。

c++对象无返回值

示例&说明

以下代码中的[native code],表示这是JavaScript的底层内部代码实现,无法显示代码细节。

// 字符串:String()var str = "张三";document.writeln(str.constructor); // function String() { [native code] }document.writeln(str.constructor === String); // true// 数组:Array()var arr = [1, 2, 3];document.writeln(arr.constructor); // function Array() { [native code] }document.writeln(arr.constructor === Array); // true// 数字:Number()var num = 5;document.writeln(num.constructor); // function Number() { [native code] }document.writeln(num.constructor === Number); // true// 自定义对象:Person()function Person(){this.name = "CodePlayer";}var p = new Person();document.writeln(p.constructor); // function Person(){ this.name = "CodePlayer"; }document.writeln(p.constructor === Person); // true// JSON对象:Object()var o = { "name" : "张三"};document.writeln(o.constructor); // function Object() { [native code] }document.writeln(o.constructor === Object); // true// 自定义函数:Function()function foo(){alert("CodePlayer");}document.writeln(foo.constructor); // function Function() { [native code] }document.writeln(foo.constructor === Function); // true// 函数的原型:bar()function bar(){alert("CodePlayer");}document.writeln(bar.prototype.constructor); // function bar(){ alert("CodePlayer"); }document.writeln(bar.prototype.constructor === bar); // true