下面小编就为大家带来一篇浅谈 javascript 中 new 操作符的原理。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
javascript 中的 new 是一个语法糖,对于学过 c++,java 和 c# 等面向对象语言的人来说,以为 js 里面是有类和对象的区别的,实现上 js 并没有类,一切皆对象,比 java 还来的彻底
new 的过程实际上是创建一个新对象,把新象的原型设置为构造器函数的原型,在使用 new 的过程中,一共有 3 个对象参与了协作,构造器函数是第一个对象,原型对象是二个,新生成了一个空对象是第三个对象,最终返回的是一个空对象,但这个空对象不是真空的,而是已经含有原型的引用(__proto__)
步骤如下:
(1) 创建一个空对象 obj
(2) 让空对象的__proto__(IE 没有该属性)成员指向了构造函数的 prototype 成员对象
(3) 使用 apply 调用构造器函数,this 绑定到空对象 obj 上。
(4) 返回空对象 obj
可以自己写个函数替代使用 new 也是完全可以的,示例代码如下:
- function NEW_OBJECT(Foo){
- var obj={};
- obj.__proto__=Foo.prototype;
- obj.__proto__.constructor=Foo;
- Foo.apply(obj,arguments)
- return obj;
- }
以上这篇浅谈 javascript 中 new 操作符的原理就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持 phperz。
来源: http://www.phperz.com/article/17/0331/265069.html