首頁 > web前端 > js教程 > 關於new 操作符的相關問題講解

關於new 操作符的相關問題講解

jacklove
發布: 2018-05-21 11:02:17
原創
1447 人瀏覽過

以下就是new 運算子的一些問題,本篇將會解釋起相關問題。

先看結果

function Person (name, age, job) {  this.name = name  this.age = age  this.job = job
}
Person.prototype.sayName = function () {  console.log(this.name)
}// 使用new操作符var p1 = new Person('laoyang', '22', 'coding')
p1 instanceof Person // true// 不使用new 操作符var p2 = new Object()
Person.call(p2, 'xiaoyang', '2', 'test')
p2.__proto__ = Person.prototype
p2 instanceof Person // true
登入後複製

比較不同

// 使用new 操作符直接创建实例var p1 = new Person('laoyang', '22', 'coding')
// 不使用new 操作符var p2 = new Object() 
// p2 创建成为一个对象 这时p2的原型是ObjectPerson.call(p2, 'xiaoyang', '2', 'test')
 // Person构造函数在 p2 对象的环境内执行 这时p2已经是一个具有Person属性的实例了,但原型是Objectp2.__proto__ = Person.prototype 
// 最后把Person.prototype 赋值给p2.__proto__,让p2的原型指向Person.prototype
登入後複製

不使用new 運算子建立實例的步驟:

Person.call(p2, 'xiaoyang', '2', 'test') // d

本篇展示了new操作符的相關問題,更多相關問題請關注php中文網。

相關推薦:

關於常見的JS函數問題的解說

JavaScript相關函數的講解

關於jquery DOM&事件的解說

#

以上是關於new 操作符的相關問題講解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
new
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板