javascript中new关键字

简介: new 关键字在JavaScript中使用构造函数的时候,我们就会用到new关键字。

new 关键字

在JavaScript中使用构造函数的时候,我们就会用到new关键字。

定义:

new关键字是用来创建一个用户自定义的对象类型实例或者具有构造函数的内置对象的实例

js中的new做了什么?

假设我们要创建一个user的新实例,这个时候我们需要使用new关键字,那我们以这种方式调用构造函数,会经历一下四个步骤:

  1. 创建一个新的对象。
  2. 将构造函数的作用域赋给新对象(所以this就指向了这个新的对象)。
  3. 执行构造函数中的代码(为我们这个新对象添加相应的属性)。这些属性就是构造函数里面的属性,我们通过这一步将构造函数的属性添加到新对象里面。
  4. 最后返回这个新对象。

我们来看看new的例子

function Test(name) {
    this.name = name
}
Test.prototype.sayName = function () {
    console.log(this.name)
}
const newTest = new Test('海绵宝宝')
console.log(newTest.name) // '海绵宝宝'
newTest.sayName() // '海绵宝宝'
复制代码

在这个例子中,我们可以看到:

  • new关键字创建了一个新的对象。
  • 并且这个新对象可以访问到构造函数的属性。
  • 这个新对象还可以访问到构造函数的方法。
  • 也就是说,我们通过new操作符将构造函数与实例对象通过原型链链接起来了。

但是上面那个例子,构造函数并没有返回任何值(默认返回undefined),要是我们让他返回值,会发生什么情况呢?

这个分为两种情况:

  1. 返回值为原始值。
  2. 返回值为对象。

我们一种一种的来看

首选我们看看返回值为原始值的时候:

function Test(name) {
    this.name = name;
    return '111';
}
const newTest = new Test('海绵宝宝');
console.log(newTest.name); // '海绵宝宝'
复制代码

上面这个例子,我们可以看到,即使我们最后返回了一个字符串,但是最后实例对象还是输出了构造函数里面的属性值。这说明这个原始值的返回类型没有任何用处。结果还是和没有返回值一样的。

接下来我们看看返回值为对象的时候,会发生什么:

function Test(name) {
    this.name = name
    console.log(this)
    return {
        name: '蟹老板'
    }
}
const Test1 = new Test('海绵宝宝')
console.log(Test1.name)  // '蟹老板'
console.log(Test1) // {name: '蟹老板'}
复制代码

通过这个例子我们知道,当构造函数里面将返回值设置为一个对象的时候,返回的对象会作为实例对象的属性。这个返回值将会被正常的使用。

总结:

构造函数尽量不要使用返回值,因为原始值的没有任何作用,返回对象的话会导致new操作符失效。


相关文章
|
4月前
|
JavaScript
ES6学习(9)js中的new实现
ES6学习(9)js中的new实现
|
2月前
|
JavaScript 前端开发 安全
ECMAScript 6(以下简称 ES6)的出现为 JavaScript 带来了许多新的特性和改进,其中 let 和 const 是两个非常重要的关键字。
ES6 引入了 `let` 和 `const` 关键字,为 JavaScript 的变量管理带来了革新。`let` 提供了块级作用域和暂存死区特性,避免变量污染,增强代码可读性和安全性;`const` 用于声明不可重新赋值的常量,但允许对象和数组的内部修改。两者在循环、函数内部及复杂项目中广泛应用,有助于实现不可变数据结构,提升代码质量。
36 5
|
2月前
|
设计模式 JavaScript 前端开发
js中new和object.creat区别
【10月更文挑战第29天】`new` 关键字和 `Object.create()` 方法在创建对象的方式、原型链继承、属性初始化以及适用场景等方面都存在差异。在实际开发中,需要根据具体的需求和设计模式来选择合适的方法来创建对象。
|
2月前
|
前端开发 JavaScript 开发者
除了 async/await 关键字,还有哪些方式可以在 JavaScript 中实现异步编程?
【10月更文挑战第30天】这些异步编程方式在不同的场景和需求下各有优劣,开发者可以根据具体的项目情况选择合适的方式来实现异步编程,以达到高效、可读和易于维护的代码效果。
|
4月前
|
JavaScript 前端开发 Java
JavaScript 保留关键字
JavaScript 保留关键字
30 2
|
4月前
|
JavaScript 前端开发
JavaScript this 关键字
JavaScript this 关键字
19 1
|
5月前
|
JavaScript 前端开发
JavaScript 语句标识符(关键字)
【8月更文挑战第29天】
31 5
|
5月前
|
JavaScript 前端开发
|
7月前
|
JavaScript 前端开发 开发者
JavaScript中的const关键字解析
JavaScript中的const关键字解析
|
7月前
|
JavaScript 前端开发
JavaScript变量命名规则及关键字详解
JavaScript变量命名规则及关键字详解
110 1