JavaScript new對象的四個過程


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);

  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM