JavaScript中的new操作符的具体使用

 更新时间:2023年05月04日 15:26:56   作者:没空铲屎的艾伦  
本文主要介绍了JavaScript中的new操作符的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

JavaScript中的new操作符是一个非常重要的概念,它可以让我们创建一个自定义的对象类型或者一个内置的对象类型,比如Array、Date、Function等。那么,new操作符到底做了什么呢?我们来一步一步分析。

new做了什么?

首先,当我们使用new操作符调用一个函数时,这个函数就会被当作一个构造函数,也就是说,它会用来创建一个新的对象实例。例如:

function Person(name) {  
    this.name = name;
}  
var p1 = new Person("Allen");  

这里,我们定义了一个Person函数,然后用new操作符创建了一个p1对象,这个对象的类型是Person,它有个name属性,赋值为"Allen"

那么,具体来说,new操作符做了哪些事情呢?我们可以总结为以下四个步骤:

  • 创建一个空的JavaScript对象,我们暂且叫它newInstance
  • 将newInstance的[[Prototype]]属性指向构造函数的prototype属性,如果prototype是一个对象的话。否则,newInstance保持为一个普通对象,它的[[Prototype]]指向Object.prototype。注意:[[Prototype]]是一个内部属性,它表示对象的原型链。通过这一步,newInstance就可以继承构造函数原型上的属性和方法。
  • 执行构造函数,并将newInstance作为this的上下文(也就是说,在构造函数中所有对this的引用都指向newInstance)。这样,构造函数就可以给newInstance添加一些自身的属性和方法。
  • 如果构造函数返回了一个非原始值(比如一个对象或者一个函数),那么这个返回值就会成为整个new表达式的结果。否则,如果构造函数没有返回任何值或者返回了一个原始值(比如一个数字或者一个字符串),那么newInstance就会成为整个new表达式的结果。(通常情况下,构造函数不会返回任何值,但是它可以选择这样做来覆盖正常的对象创建过程。)

例如:

function Foo(bar) {  
    this.bar = bar;  
}  
Foo.prototype.baz = function() {  
    console.log(this.bar);  
};  
var f1 = new Foo("Hello"); // f1是Foo类型的对象,它有bar属性和baz方法  
var f2 = new Foo("World"); // f2也是Foo类型的对象,它也有bar属性和baz方法  
f1.baz(); // Hello  
f2.baz(); // World  
function Bar() {  
    return {  
        name: "Bar"  
    };  
}  
var b1 = new Bar(); // b1是一个普通对象,它有name属性  
console.log(b1 instanceof Bar); // false  

这里,我们定义了两个函数Foo和Bar,并用new操作符创建了f1、f2和b1三个对象。可以看到,f1和f2都是Foo类型的对象,它们继承了Foo.prototype上的baz方法,并且有自己的bar属性。而b1则是一个普通对象,它只有name属性,并不属于Bar类型,因为Bar函数返回了一个对象。

如何手写一个new

底层实现上,class还是基于原型继承和构造函数的。基于这个理解:

function newInstance(constructor, ...args) {
  // 创建一个空对象,且 __proto__ 指向 constructor.prototype
  const obj = Object.create(constructor.prototype);
  // 执行构造函数并绑定 this 到新对象上
  const result = constructor.apply(obj, args);
  // 如果构造函数返回了一个对象,则返回该对象
  if (result && (typeof result === "object" || typeof result === "function")) {
    return result;
  }
  // 否则返回新对象
  return obj;
}
// 示例使用
function Person(name) {
  this.name = name;
}
Person.prototype.greet = function() {
  console.log(`Hello, I'm ${this.name}.`);
};
const person1 = newInstance(Person, "Allen");
person1.greet(); // 输出 "Hello, I'm Allen."

上述代码中,myNew 函数模拟了 new 操作符的行为,它接受两个参数:构造函数和构造函数的参数,返回一个新的实例对象。在函数内部,首先创建了一个新的空对象 obj,然后将该对象的 __proto__ 属性指向构造函数的原型对象,从而实现了原型继承。接着将构造函数的 this 绑定到新对象上,并执行构造函数。如果构造函数返回的是一个对象,则直接返回该对象,否则返回新创建的对象 obj

到此这篇关于JavaScript中的new操作符的具体使用的文章就介绍到这了,更多相关JavaScript new操作符内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 原生js实现购物车逻辑和功能

    原生js实现购物车逻辑和功能

    这篇文章主要为大家详细介绍了原生js实现购物车逻辑和功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • Three.js+React制作3D梦中海岛效果

    Three.js+React制作3D梦中海岛效果

    深居内陆的人们,大概每个人都有过大海之梦吧。本文使用React+Three.js技术栈,实现3D海洋和岛屿,感兴趣的小伙伴可以跟随小编一起学习一下
    2022-05-05
  • 纯js实现的论坛常用的运行代码的效果

    纯js实现的论坛常用的运行代码的效果

    bluidea论坛的脚本板块的版主写的,不错,转到这!
    2008-07-07
  • js 冒泡事件与事件监听使用分析

    js 冒泡事件与事件监听使用分析

    js 冒泡事件与事件监听 代码分析
    2009-09-09
  • 如何用JS判断两个数字的大小

    如何用JS判断两个数字的大小

    在JS的学习中,我们经常可能碰到这样的问题,本文用实例演示如何正确的用JS判断两个数字的大小。
    2016-07-07
  • JS实现获取本月的开始时间与结束时间

    JS实现获取本月的开始时间与结束时间

    在JavaScript中,可以使用Date对象来获取本月的开始时间和结束时间,本文通过代码示例详细的给大家介绍了JS获取本月的开始时间与结束时间,感兴趣的小伙伴跟着小编一起来看看吧
    2023-08-08
  • 原生js jquery ajax请求以及jsonp的调用方法

    原生js jquery ajax请求以及jsonp的调用方法

    下面小编就为大家带来一篇原生js jquery ajax请求以及jsonp的调用方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • javascript学习笔记之10个原生技巧

    javascript学习笔记之10个原生技巧

    首先在这里要非常感谢无私分享作品的网友们,这些代码片段主要由网友们平时分享的作品代码里面和经常去逛网站然后查看源文件收集到的。把平时网站上常用的一些实用功能代码片段通通收集起来,方便网友们学习使用,利用好的话可以加快网友们的开发速度,提高工作效率。
    2014-05-05
  • JavaScript数据结构与算法之栈详解

    JavaScript数据结构与算法之栈详解

    栈作为一种数据结构,是一种只能在一端进行插入和删除操作的特殊线性表,也成称为先进后出表,下面这篇文章主要给大家介绍了关于JavaScript数据结构与算法之栈的相关资料,需要的朋友可以参考下
    2022-06-06
  • 关于JavaScript奇怪又实用的六个姿势

    关于JavaScript奇怪又实用的六个姿势

    这篇文章主要给大家介绍了关于JavaScript奇怪又实用的六个姿势,这些技巧和建议是我平常在开发项目上会用到的,希望能让大家学到知识,需要的朋友可以参考下
    2021-10-10

最新评论