当前位置: 首页 > news >正文

网站建设责任分解谷歌seo 外贸建站

网站建设责任分解,谷歌seo 外贸建站,物联网工程就业方向及前景,wordpress打开html文章目录 一、前言二、new.target 重写三、拓展阅读 一、前言 源码阅读过程中,发现以下语句 new.target.prototype鉴于该语法为es6所有,项目在编译过程中,控制台报Unexpected token: punc(.)错误。按照常规处理,应用babel-loade…

文章目录

    • 一、前言
    • 二、new.target 重写
    • 三、拓展阅读

一、前言

源码阅读过程中,发现以下语句

new.target.prototype

鉴于该语法为es6所有,项目在编译过程中,控制台报Unexpected token: punc(.)错误。按照常规处理,应用babel-loader即可解决此类问题。在.babelrc

{"presets": [["es2015"]]
}

经过实践发现,build阶段依旧报错。

故采用第二套解决方案,使用es5语法重写es6

二、new.target 重写

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

 1     function Person( uName ){2         if ( this instanceof Person ) {3             this.userName = uName;4         }else {5             return new Person( uName );6         }7     }8     Person.prototype.showUserName = function(){9         return this.userName;
10     }
11     console.log( Person( 'ghostwu' ).showUserName() );
12     console.log( new Person( 'ghostwu' ).showUserName() );

es6中,为了识别函数调用时,是否使用了new关键字,引入了一个新的属性new.target:

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

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

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

1         function Person( uName ){
2             if( new.target !== undefined ){
3                 this.userName = uName;
4             }else {
5                 throw new Error( '必须用new实例化' );
6             }
7         }
8         // Person( 'ghostwu' ); //报错
9         console.log( new Person( 'ghostwu' ).userName ); //ghostwu

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

 1         function Person( uName ){2             if ( new.target === Person ) {3                 this.userName = uName;4             }else {5                 throw new Error( '必须用new实例化' );6             }7         }8         9         // Person( 'ghostwu' ); //报错
10         console.log( new Person( 'ghostwu' ).userName ); //ghostwu
 1         class Person{2             constructor( uName ){3                 if ( new.target === Person ) {4                     this.userName = uName;5                 }else {6                     throw new Error( '必须要用new关键字' );7                 }8             }            9         }
10 
11         // Person( 'ghostwu' ); //报错
12         console.log( new Person( 'ghostwu' ).userName ); //ghostwu

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

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

 1         let Person = ( function(){2             'use strict';3             const Person = function( uName ){4                 if ( new.target !== undefined ){5                     this.userName = uName;6                 }else {7                     throw new Error( '必须使用new关键字' );8                 }9             }
10 
11             Object.defineProperty( Person.prototype, 'sayName', {
12                 value : function(){
13                     if ( typeof new.target !== 'undefined' ) {
14                         throw new Error( '类里面的方法不能使用new关键字' );
15                     }
16                     return this.userName;
17                 },
18                 enumerable : false,
19                 writable : true,
20                 configurable : true
21             } );
22 
23             return Person;
24         })();
25 
26         console.log( new Person( 'ghostwu' ).sayName() );
27         console.log( Person( 'ghostwu' ) ); //没有使用new,报错

三、拓展阅读

  • 《JavaScript进阶(二十六):ES各版本特性详解》
http://www.mnyf.cn/news/46165.html

相关文章:

  • 免费的网站管理系统搜索引擎营销分析
  • 企业网站关站外贸接单平台
  • 济南 营销型网站建设seo搜索引擎优化视频
  • 国产手机做系统下载网站站长工具seo综合查询工具
  • 女和男做的视频网站谷歌浏览器怎么下载
  • 一个网站怎么做多条线路免费的网站平台
  • 网页设计咨询seo学习网站
  • 网站建设代理推广徽信xiala5效果好百度总部
  • 网站建设四川推来客网站系统网页设计论文
  • 烟台 o2o平台带动做网站行业郑州网站关键词优化公司哪家好
  • 电子商务网站建设与管理的论文网络营销的盈利模式
  • 360提示危险的网站太原关键词优化报价
  • 阿里云可以做哪些网站百度关键词下拉有什么软件
  • 优化网站排名公司常见的网站推广方法有哪些
  • 盱眙网站建设石家庄最新疫情
  • 女生做网站后期维护工作好吗推广app的单子都在哪里接的
  • win主机怎样实现wordpress固定链接静态化重庆seo网站哪家好
  • b s架构做网站好处产品市场营销策划书
  • 网站域名 代办seo咨询解决方案
  • 郑州交友网站建设磁力蜘蛛
  • 网站开发需要什么配置的电脑淘宝seo培训
  • 太原建站方法谷歌浏览器下载官方正版
  • 电子商务网站开发方案西安网站seo诊断
  • 手机怎么做电子书下载网站seo怎么推排名
  • 导航网站链接怎么做windows优化
  • 织梦做网站好不好网络服务运营商
  • 深圳公司做网站关键词词库
  • 教育网站建设计划书百度集团
  • wordpress做的好的网站基本营销策略有哪些
  • 哪里有南宁网站建设aso优化报价