js es6系列教程 - 基于new.target属性与es5改造es6的类语法


Posted in Javascript onSeptember 02, 2017

es5的构造函数前面如果不用new调用,this指向window,对象的属性就得不到值了,所以以前我们都要在构造函数中通过判断this是否使用了new关键字来确保普通的函数调用方式都能让对象复制到属性

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中,为了识别函数调用时,是否使用了new关键字,引入了一个新的属性new.target:

1,如果函数使用了new,那么new.target就是构造函数

2,如果函数没有用new,那么new.target就是undefined

3,es6的类方法中,在调用时候,使用new,new.target指向类本身,没有使用new就是undefined

function Person( uName ){
   if( new.target !== undefined ){
    this.userName = uName;
   }else {
    throw new Error( '必须用new实例化' );
   }
  }
  // Person( 'ghostwu' ); //报错
  console.log( new Person( 'ghostwu' ).userName ); //ghostwu

使用new之后, new.target就是Person这个构造函数,那么上例也可以用下面这种写法:

function Person( uName ){
   if ( new.target === Person ) {
    this.userName = uName;
   }else {
    throw new Error( '必须用new实例化' );
   }
  }
  
  // Person( 'ghostwu' ); //报错
  console.log( new Person( 'ghostwu' ).userName ); //ghostwu
class Person{
   constructor( uName ){
    if ( new.target === Person ) {
     this.userName = uName;
    }else {
     throw new Error( '必须要用new关键字' );
    }
   }   
  }

  // Person( 'ghostwu' ); //报错
  console.log( new Person( 'ghostwu' ).userName ); //ghostwu

上例,在使用new的时候, new.target等于Person

掌握new.target之后,接下来,我们用es5语法改写上文中es6的类语法

let Person = ( function(){
   'use strict';
   const Person = function( uName ){
    if ( new.target !== undefined ){
     this.userName = uName;
    }else {
     throw new Error( '必须使用new关键字' );
    }
   }

   Object.defineProperty( Person.prototype, 'sayName', {
    value : function(){
     if ( typeof new.target !== 'undefined' ) {
      throw new Error( '类里面的方法不能使用new关键字' );
     }
     return this.userName;
    },
    enumerable : false,
    writable : true,
    configurable : true
   } );

   return Person;
  })();

  console.log( new Person( 'ghostwu' ).sayName() );
  console.log( Person( 'ghostwu' ) ); //没有使用new,报错

以上这篇js es6系列教程 - 基于new.target属性与es5改造es6的类语法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
利用jQuery的$.event.fix函数统一浏览器event事件处理
Dec 21 Javascript
仅IE支持clearAttributes/mergeAttributes方法使用介绍
May 04 Javascript
Jquery为单选框checkbox绑定单击click事件
Dec 18 Javascript
屏蔽网页右键复制和ctrl+c复制的js代码
Jan 04 Javascript
jquery实现横向图片轮播特效代码分享
Nov 19 Javascript
基于AGS JS开发自定义贴图图层
Mar 31 Javascript
React Navigation 使用中遇到的问题小结
May 08 Javascript
Vue中的情侣属性$dispatch和$broadcast详解
Mar 07 Javascript
改进 JavaScript 和 Rust 的互操作性并深入认识 wasm-bindgen 组件
Jul 13 Javascript
vscode中eslint插件的配置(prettier配置无效)
Sep 10 Javascript
JS实现图片切换特效
Dec 23 Javascript
js实现中文实时时钟
Jan 15 Javascript
js es6系列教程 - 新的类语法实战选项卡(详解)
Sep 02 #Javascript
使用vue-resource进行数据交互的实例
Sep 02 #Javascript
jquery tmpl模板(实例讲解)
Sep 02 #jQuery
自制简易打赏功能的实例
Sep 02 #Javascript
Vue使用vue-cli创建项目
Sep 01 #Javascript
vue 里面使用axios 和封装的示例代码
Sep 01 #Javascript
ionic2懒加载配置详解
Sep 01 #Javascript
You might like
使用XDebug调试及单元测试覆盖率分析
2011/01/27 PHP
PHP循环函数使用介绍之PHP基础入门教程
2013/09/21 PHP
php导出csv文件,可导出前导0实例代码
2016/11/16 PHP
php 常用的系统函数
2017/02/07 PHP
使用JQUERY Tabs插件宿主IFRAMES
2010/01/01 Javascript
表单类各种类型(文本框)失去焦点效果jquery代码
2013/04/26 Javascript
jquery text()方法取标签中的文本
2014/07/25 Javascript
PHPExcel中的一些常用方法汇总
2015/01/23 Javascript
JS使用ajax方法获取指定url的head信息中指定字段值的方法
2015/03/24 Javascript
在JavaScript中使用对数Math.log()方法的教程
2015/06/15 Javascript
JavaScript对象参数的引用传递
2016/01/14 Javascript
Sea.JS知识总结
2016/05/05 Javascript
实现两个文本框同时输入的实例
2017/09/25 Javascript
jackson解析json字符串,首字母大写会自动转为小写的方法
2017/12/22 Javascript
JavaScript实现的DOM树遍历方法详解【二叉DOM树、多叉DOM树】
2018/05/07 Javascript
JavaScript设计模式之单例模式原理与用法实例分析
2018/07/26 Javascript
详解如何在Node.js的httpServer中接收前端发送的arraybuffer数据
2018/11/11 Javascript
js实现拖拽与碰撞检测
2020/09/18 Javascript
六个窍门助你提高Python运行效率
2015/06/09 Python
ubuntu系统下 python链接mysql数据库的方法
2017/01/09 Python
python读取和保存视频文件
2018/04/16 Python
对python的unittest架构公共参数token提取方法详解
2018/12/17 Python
Tensorflow 模型转换 .pb convert to .lite实例
2020/02/12 Python
python如何处理程序无法打开
2020/06/16 Python
python爬虫要用到的库总结
2020/07/28 Python
HTML5 Canvas图像模糊完美解决办法
2018/02/06 HTML / CSS
加拿大拼图大师:Puzzle Master
2020/12/28 全球购物
中科创达面试题
2016/12/28 面试题
财务人员担保书
2014/05/13 职场文书
办公楼租房协议书范本
2014/11/25 职场文书
优秀教师先进材料
2014/12/16 职场文书
法制教育主题班会
2015/08/13 职场文书
爱岗敬业事迹材料
2019/06/20 职场文书
Golang 如何实现函数的任意类型传参
2021/04/29 Golang
MySQL系列之十四 MySQL的高可用实现
2021/07/02 MySQL
排查并解决MySQL生产库内存使用率高的报警
2022/04/11 MySQL