js构造函数 实例与new对象

Posted zhangzheng022

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js构造函数 实例与new对象相关的知识,希望对你有一定的参考价值。

构造函数函数特点

1.函数体内使用了this关键字,代表了所要生成的对象实例

2.生成对象的时候必须使用new命令

3每个函数都自动添加一个名称为prototype属性,这是一个对象

4每个对象内部都有一个属性_proto_(规范没有这个名称,但是浏览器都是这么实现)

5指向其类型的prototype,类的实例也是对象,其_prototype_属性指向类的prototype

new命令的作用,就是执行构造函数,返回一个实例对象。

使用new命令是,他后面的函数执行下面的步骤

1创建一个空对象,作为将要返回的对象实例

2将这个空对象的原型,指向构造函数的prototype属性

3将这个空对象复制给函数内部this关键字

4开始执行构造函数内部的代码

如果构造函数内部return语句,后面跟着一个对象,

new命令会返回renturn语句指定的对象否则不管return语句,返回this

var Vehicle = function () 
  this.price = 1000;
  return 1000;
;

(new Vehicle()) === 1000
// false

上面代码中,构造函数Vehicle的return语句返回一个数值。这时,new命令就会忽略这个return语句,返回“构造”后的this对象。

但是,如果return语句返回的是一个跟this无关的新对象,new命令会返回这个新对象,而不是this对象。这一点需要特别引起注意。

function _new(/* 构造函数 */ constructor, /* 构造函数参数 */ params) 
  // 将 arguments 对象转为数组
  var args = [].slice.call(arguments);
  // 取出构造函数
  var constructor = args.shift();
  // 创建一个空对象,继承构造函数的 prototype 属性
  var context = Object.create(constructor.prototype);
  // 执行构造函数
  var result = constructor.apply(context, args);
  // 如果返回结果是对象,就直接返回,否则返回 context 对象
  return (typeof result === 'object' && result != null) ? result : context;


// 实例
var actor = _new(Person, '张三', 28);

new target 使用这个属性可以判断函数调用时候是否使用new

function f() 
  if (!new.target) 
    throw new Error('请使用 new 命令调用!');
  
  // ...


f() // Uncaught Error: 请使用 new 命令调用!

instanceof 是一个操作符可以判断对象是否为某种类型的实例

p1 instanceof Person; // true

以上是关于js构造函数 实例与new对象的主要内容,如果未能解决你的问题,请参考以下文章

浅谈JS中的构造函数原型对象(prototype)实例中的属性/方法之间的关系

实例对象与new命令

JS构造函数加new与不加new的区别?

JS原型和继承

JS原型对象

JS:构造函数