一篇就夠-JS的new實現(xiàn)

new的作用

function Fruit(name){
    this.name = name;
}
Fruit.prototype.show = function(){
    console.log(this.name);
}

var banana = new Fruit('banana');
//輸出Fruit.protoype
console.log(Object.getPrototypeOf(banana));
//輸出Fruit.prototype
console.log(banana.__proto__);
//輸出'banana'
console.log(banana.show());
//輸出'banana'
console.log(banana.name);
//輸出true
console.log(banana.hasOwnProperty("name"));
//輸出false
console.log(banana.hasOwnProperty("show"));

可以看到毕籽,經(jīng)過new之后返回了一個對象兽愤,該對象的構(gòu)造函數(shù)原型為Fruit.prototype,也就是proto指向Fruit.prototype
并且banana可以調(diào)用show和name屬性,但name是其擁有的屬性,show是原型上的屬性胀屿。
也就是new做了以下幾件事

  • 返回一個對象,該對象的proto指向構(gòu)造函數(shù)的原型
  • 該對象會實現(xiàn)構(gòu)造函數(shù)中的實例屬性揭鳞,也就是調(diào)用構(gòu)造函數(shù)的apply方法

初步實現(xiàn)new操作符

function objectFactory(paramConstrutor){
    if(typeof paramConstrutor !== 'function' ){
        throw new Error("");
    }
    var args = Array.prototype.slice.call(arguments,1);
    //設(shè)置obj的proto為constructor的proto,也就是繼承共享屬性
    //兩種方式逛拱,
    //一種是直接設(shè)置__proto__,官方不建議,后面可能變成只讀屬性
    var obj = new Object();
    obj.__proto__ = paramConstrutor.prototype;
    //一種是通過Object.create()或者該方式的polyfill
    //模擬Object.create()
    function Empty(){};
    Empty.prototype = paramConstructor.prototype;
    var obj = new Empty();
    //繼承實例屬性
    paramConstructor.apply(obj,args);
    return obj;
}

如果構(gòu)造函數(shù)由返回值滴须,那應(yīng)該是返回新建的對象還是返回值呢舌狗?

  • 直接返回返回值,當返回值是Object扔水、Function痛侍、Array、Date、RegExg主届、Error
  • 返回新建對象赵哲,當返回值是Null、Undefined君丁、Number枫夺、Boolean、String绘闷、Symbol
function Fruit(name){
    this.name = name;
    return {
        a:1
    }
}

var banana = new Fruit('banana');
//{a:1}
console.log(banana);
function Fruit(name){
    this.name = name;
    return 1;
}

var banana = new Fruit('banana');
//Fruit {name:'banana‘}
console.log(banana);

完整代碼

根據(jù)上面的返回值橡庞,進一步完善代碼。
需要了解的:

  • typeof檢測除了Function之外的都為object
  • typeof檢測Null為object
function objectFactory(paramConstructor){
    if(typeof paramConstructor !== 'function'){
        throw new Error("");
    }
    var args = Array.prototype.slice.call(arguments,1);
    //繼承共享屬性印蔗,修改proto屬性
    function Empty(){};
    Empty.prototype = paramConstructor.prototype;
    var obj = new Empty();
    //繼承實例屬性
    var result = paramConstructor.apply(obj,args);
    var isObejct = typeof result === 'object' && result !== null;
    var isFunction = typeof result === 'function';
    if(isObejct ||isFunction ){
        return result
    }
    return obj;
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末扒最,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子华嘹,更是在濱河造成了極大的恐慌吧趣,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件耙厚,死亡現(xiàn)場離奇詭異强挫,居然都是意外死亡,警方通過查閱死者的電腦和手機薛躬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進店門俯渤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人泛豪,你說我怎么就攤上這事稠诲。” “怎么了诡曙?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵臀叙,是天一觀的道長。 經(jīng)常有香客問我价卤,道長劝萤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任慎璧,我火速辦了婚禮床嫌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘胸私。我一直安慰自己厌处,他們只是感情好,可當我...
    茶點故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布岁疼。 她就那樣靜靜地躺著阔涉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上瑰排,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天贯要,我揣著相機與錄音,去河邊找鬼椭住。 笑死崇渗,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的京郑。 我是一名探鬼主播宅广,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼傻挂!你這毒婦竟也來了乘碑?” 一聲冷哼從身側(cè)響起挖息,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤金拒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后套腹,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體绪抛,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年电禀,在試婚紗的時候發(fā)現(xiàn)自己被綠了幢码。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,747評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡尖飞,死狀恐怖症副,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情政基,我是刑警寧澤贞铣,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站沮明,受9級特大地震影響辕坝,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜荐健,卻給世界環(huán)境...
    茶點故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一酱畅、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧江场,春花似錦纺酸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春用含,著一層夾襖步出監(jiān)牢的瞬間矮慕,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工啄骇, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留痴鳄,地道東北人。 一個月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓缸夹,卻偏偏與公主長得像痪寻,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子虽惭,可洞房花燭夜當晚...
    茶點故事閱讀 43,658評論 2 350

推薦閱讀更多精彩內(nèi)容