国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開發(fā) > JS > 正文

js es6系列教程 - 基于new.target屬性與es5改造es6的類語(yǔ)法

2024-05-06 16:39:24
字體:
供稿:網(wǎng)友

es5的構(gòu)造函數(shù)前面如果不用new調(diào)用,this指向window,對(duì)象的屬性就得不到值了,所以以前我們都要在構(gòu)造函數(shù)中通過判斷this是否使用了new關(guān)鍵字來確保普通的函數(shù)調(diào)用方式都能讓對(duì)象復(fù)制到屬性

function Person( uName ){  if ( this instanceof Person ) {   this.userName = uName;  }else {   return new Person( uName );  } } Person.prototype.showUserName = function(){  return this.userName; } console.log( Person( 'ghostwu' ).showUserName() ); console.log( new Person( 'ghostwu' ).showUserName() );

在es6中,為了識(shí)別函數(shù)調(diào)用時(shí),是否使用了new關(guān)鍵字,引入了一個(gè)新的屬性new.target:

1,如果函數(shù)使用了new,那么new.target就是構(gòu)造函數(shù)

2,如果函數(shù)沒有用new,那么new.target就是undefined

3,es6的類方法中,在調(diào)用時(shí)候,使用new,new.target指向類本身,沒有使用new就是undefined

function Person( uName ){   if( new.target !== undefined ){    this.userName = uName;   }else {    throw new Error( '必須用new實(shí)例化' );   }  }  // Person( 'ghostwu' ); //報(bào)錯(cuò)  console.log( new Person( 'ghostwu' ).userName ); //ghostwu

使用new之后, new.target就是Person這個(gè)構(gòu)造函數(shù),那么上例也可以用下面這種寫法:

function Person( uName ){   if ( new.target === Person ) {    this.userName = uName;   }else {    throw new Error( '必須用new實(shí)例化' );   }  }    // Person( 'ghostwu' ); //報(bào)錯(cuò)  console.log( new Person( 'ghostwu' ).userName ); //ghostwu
class Person{   constructor( uName ){    if ( new.target === Person ) {     this.userName = uName;    }else {     throw new Error( '必須要用new關(guān)鍵字' );    }   }     }  // Person( 'ghostwu' ); //報(bào)錯(cuò)  console.log( new Person( 'ghostwu' ).userName ); //ghostwu

上例,在使用new的時(shí)候, new.target等于Person

掌握new.target之后,接下來,我們用es5語(yǔ)法改寫上文中es6的類語(yǔ)法

let Person = ( function(){   'use strict';   const Person = function( uName ){    if ( new.target !== undefined ){     this.userName = uName;    }else {     throw new Error( '必須使用new關(guān)鍵字' );    }   }   Object.defineProperty( Person.prototype, 'sayName', {    value : function(){     if ( typeof new.target !== 'undefined' ) {      throw new Error( '類里面的方法不能使用new關(guān)鍵字' );     }     return this.userName;    },    enumerable : false,    writable : true,    configurable : true   } );   return Person;  })();  console.log( new Person( 'ghostwu' ).sayName() );  console.log( Person( 'ghostwu' ) ); //沒有使用new,報(bào)錯(cuò)

以上這篇js es6系列教程 - 基于new.target屬性與es5改造es6的類語(yǔ)法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到JavaScript/Ajax教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 广南县| 无极县| 广平县| 泽普县| 博客| 宁德市| 潮安县| 中超| 应城市| 扬州市| 彭泽县| 陕西省| 南溪县| 卫辉市| 汝阳县| 景德镇市| 天水市| 鄂温| 元谋县| 江西省| 广州市| 启东市| 秭归县| 肃南| 洪洞县| 天台县| 周口市| 新兴县| 新津县| 咸宁市| 故城县| 固始县| 西丰县| 黎城县| 马关县| 精河县| 松桃| 股票| 民乐县| 光山县| 扬中市|