當(dāng)前位置:
首頁(yè) >
前端技术
> javascript
>内容正文
javascript
JavaScript new对象的四个过程
生活随笔
收集整理的這篇文章主要介紹了
JavaScript new对象的四个过程
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
new 一個(gè)對(duì)象
function Person(name, age) { this.name = name; this.age = age; } var person = new Person("hellen", 23);?
1、創(chuàng)建一個(gè)空對(duì)象
var obj = new Object();2、讓Person中的this指向obj,并執(zhí)行Person的函數(shù)體
var result = Person.apply(obj,arguments);3、設(shè)置原型鏈,將obj的__proto__成員指向了Person函數(shù)對(duì)象的prototype成員對(duì)象
obj.__proto__ = Person.prototype;4、判斷Person的返回值類型,如果是值類型,返回obj。如果是引用類型,就返回這個(gè)引用類型的對(duì)象。
if (typeof(result) == "object") person = result; elseperson = 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);
?
轉(zhuǎn)載于:https://www.cnblogs.com/xiaosongJiang/p/11005193.html
總結(jié)
以上是生活随笔為你收集整理的JavaScript new对象的四个过程的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: bzoj4788: [CERC2016]
- 下一篇: 一条数据的漫游 -- X-Engine