JavaScript

javascript中new操作符的原理

时间:2024-09-17 10:42:04 JavaScript 我要投稿
  • 相关推荐

javascript中new操作符的原理

  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中new操作符的原理】相关文章:

如何调试javascript脚本呢07-19

javascript跨域访问的方法07-19

关于OrCad原理图设计中模块化的调用07-12

数码相机的曝光原理06-08

色彩搭配原理和技巧09-04

母乳的乳汁分泌原理知识02-08

亚伟速录机的原理07-26

高尔夫的短杆原理及练习要点09-05

原理图设计基础简介07-22

滑移装载机的工作原理02-01