详细讲解javascript中new操作符的原理(图文教程)
程序员文章站
2022-04-07 23:14:32
...
下面我就为大家带来一篇浅谈javascript中new操作符的原理。现在就分享给大家,也给大家做个参考。
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操作符的原理(图文教程)的详细内容,更多请关注其它相关文章!
上一篇: 一些相关的模块化基础
推荐阅读
-
详细解读在JavaScript中实现设计模式中的适配器模式的方法(图文教程)
-
JavaScript中的操作符类型转换(图文教程)
-
浅谈javascript中new操作符的原理
-
浅谈javascript中new操作符的原理
-
重点讲解在JavaScript中的__proto__属性(图文教程)
-
Javascript中的迭代、归并方法详细解读(图文教程)
-
实例讲解JavaScript中的this指向错误解决方法(图文教程)
-
详细解读JavaScript中双等号引起的隐性类型转换(图文教程)
-
详细解读JavaScript中双等号引起的隐性类型转换(图文教程)
-
详细讲解javascript中new操作符的原理(图文教程)