在 JavaScript 中, 通过 new 操作符可以创建一个实例对象,而这个实例对象继承了原对象的属性和方法。因此,new 存在的意义在于它实现了 JavaScript 中的继承,而不仅仅是实例化了一个对象。
我们先通过例子来了解 new 的作用,示例如下:
function Person(name) { this.name = name}Person.pr
[JavaScript] 纯文本查看 复制代码 function Person(name) {
this.name = name
}
Person.prototype.sayName = function () {
console.log(this.name)
}
const t = new Person('小明')
console.log(t.name) // 小明
t.sayName() // 小明
从上面的例子中我们可以得出以下结论:
构造函数 Person 并没有显式 return 任何值(默认返回 undefined ),如果我们让它返回值会发生什么事情呢?
[mw_shl_code=javascript,true]function Person(name) {
this.name = name
return 1
}
const t = new Person('小明')
console.log(t.name) // 小明
在上述例子中的构造函数中返回了 1,但是这个返回值并没有任何的用处,得到的结果还是和之前的例子完全一样。我们又可以得出一个结论:构造函数如果返回原始值,那么这个返回值毫无意义。
我们再来试试返回对象会发生什么:
[JavaScript] 纯文本查看 复制代码 function Person(name) {
this.name = name
return {age: 23}
}
const t = new Person('小明')
console.log(t) // { age: 23 }
console.log(t.name) // undefined
通过上面这个例子我们可以发现,当返回值为对象时,这个返回值就会被正常的返回出去。我们再次得出了一个结论:构造函数如果返回值为对象,那么这个返回值会被正常使用。
总结:这两个例子告诉我们,构造函数尽量不要返回值。因为返回原始值不会生效,返回对象会导致 new 操作符没有作用。
|