码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript new对象的四个过程

时间:2019-06-11 19:30:25      阅读:186      评论:0      收藏:0      [点我收藏+]

标签:name   引用类型   ==   turn   rip   设置   ===   arguments   app   

new 一个对象

function Person(name, age) {  
	this.name = name;  
	this.age = age;   
}  
var person = new Person("hellen", 23);

 

1、创建一个空对象

var obj = new Object(); 

2、让Person中的this指向obj,并执行Person的函数体

var result = Person.apply(obj,arguments);  

3、设置原型链,将obj的__proto__成员指向了Person函数对象的prototype成员对象

obj.__proto__ = Person.prototype; 

4、判断Person的返回值类型,如果是值类型,返回obj。如果是引用类型,就返回这个引用类型的对象。

if (typeof(result) == "object") 
	person = result;  
else
	person = obj;

 

function Person (name, age) {
  this.name = name;
  this.age = age;
}
Person.prototype.sayName = function () {
  console.log(this.name);
};
var person = new Person(‘Hellen‘, 23);
person.sayName();
console.log(person instanceof Person);

function New () {
  let obj = new Object();
  let fn = [].shift.call(arguments);
  let args = arguments;
  var ret = fn.apply(obj, args);
  obj.__proto__ = fn.prototype;
  return typeof ret === ‘object‘ ? ret : obj;
}
let person1 = New(Person, ‘Bob‘, 23);
person1.sayName();
console.log(person1 instanceof Person);

  

 

JavaScript new对象的四个过程

标签:name   引用类型   ==   turn   rip   设置   ===   arguments   app   

原文地址:https://www.cnblogs.com/xiaosongJiang/p/11005193.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!