javascript的new关键字用法是什么?怎样实现一个new?
Admin 2021-08-20 群英技术资讯 1315 次浏览
javascript的new关键字用法是什么?关于new关键字,大家应该都比较熟悉,这篇文章主要给大家分享构造函数、new操作符和如何实现一个new,小编觉得挺实用的,感兴趣的朋友就继续往下看吧。
在介绍new之前,必须要知道什么是构造函数。
构造函数和普通函数在写法上没有任何区别,当一个函数通过new Fun()调用时,就叫做构造函数,构造函数首字母通常大写。
function User(name) {
this.name = name;
}
let u = new User('leo');
这里,User就是构造函数,当然你也可以直接调用User(),但是这样就起不到创建实例的作用,在非严格模式下,会把name属性挂在window上。
那么new操作符到底做了什么事情呢,可以创建出一个实例?
new运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象的实例。new关键字会进行如下的操作:
1.创建一个空的简单JavaScript对象(即**{}**);
2.链接该对象(即设置该对象的构造函数)到另一个对象 ;
3.将步骤1新创建的对象作为**this**的上下文 ;
4.如果该函数没有返回对象,则返回**this**。
以上引用自new 操作符 - MDN
可能第 2、4 步大家看的不是很明白,这里我重新总结一下这 4 个步骤:
1.创建一个空对象u = {}
2.绑定原型,u.__proto__ = User.prototype
3.调用User()函数,并把空对象u当做this传入,即User.call(u)
4.如果User()函数执行完自己return一个object类型,那么返回此变量,否则返回this,注意:如果构造函数返回基本类型值,则不影响,还是返回this
知道了new操作符的原理,下面我们自己来实现一个FakeNew函数。
function FakeNew() {
let obj = {};
// 将类数组 arguments 转为数组,同时将第一个参数也就是构造函数 shift 出来
let constructor = [].shift.apply(arguments);
// 绑定原型
obj.__proto__ = constructor.prototype;
// 调用构造函数,将 obj 当做 this 传入
let res = Constructor.apply(obj, arguments);
// 返回
return typeof res === 'object' ? res : obj;
}
function User(name) {
this.name = name;
}
User.prototype.getName = function() {
return this.name;
}
let u = FakeNew(User, 'leo');
console.log(u);
console.log(u.getName());
相应关键步骤的注释已经附在代码里面了,这样我们就实现了一个new操作,相信大家以后再看到new,会有一种通透的感觉了。
以上就是关于javascript中new关键字的相关介绍,希望对大家学习javascript有帮助,想要了解更多new关键字的内容,请搜索群英网络以前的文章或继续浏览下面的相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
常见的js事件有哪些?JS事件指再浏览器窗体或者HTML元素上发生的,乐意触发JS代码块运行的行为,这篇文章主要给大家介绍窗体事件、鼠标事件和键盘事件等等,感兴趣的朋友就接着往下看吧。
我们在访问一些网站的时候,经常能看到一些自动弹出和关闭的广告,也就是广告自动出现几秒又消失的效果,接下来小编就给大家介绍怎样用来实现这一功能。
在本篇文章里小编给大家整理的是一篇关于js用正则表达式筛选年月日的实例方法,对此有兴趣的朋友们可以学习下。
这篇文章主要介绍了javascript的基础交互详解,文章通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
怎样用js实现图片隐藏和显示效果?图片的隐藏和显示效果我们经常能在网站上看到,这个功能也是比较实用的,很多朋友想要知道如何用JavaScript来实现图片隐藏和显示,下面小编就给大家分享一些js实现图片隐藏和显示的代码供大家参考。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008