1.原型 prototype
?原型上存放函数
-
解决了同一个 say 浪费 内存的问题 -
解决了污染全局变量的问题
function createStudent(name, age) {
this.name = name;
this.age = age;
}
// 将刚才的全局函数say 直接挂载到 构造函数的原型上 即可
// prototype 是个对象 每一个构造函数都会内置有的. 我们称之为原型
createStudent.prototype.say = function () {
console.log(this.name);
}
const obj = new createStudent("海海", 18);
const obj1 = new createStudent("海海呀", 19);
console.log(obj.say === obj1.say); // true
?原型解释
data:image/s3,"s3://crabby-images/4e2d1/4e2d1a4f7a8883733bbe1b724a87405a8f2d3308" alt=""
2.原型 proto
实例的 proto 属性 等于 构造函数的 prototype
3.原型的关系
所有的构造函数都是Function的实例
Array 和 Person 和 Date 等都是 Function的实例
data:image/s3,"s3://crabby-images/e8ab8/e8ab8f80f93ea39e7a812b74eca05bb629034d87" alt=""
Function 和 Object的关系
console.log(Object.prototype===Function.prototype.__proto__)
?
data:image/s3,"s3://crabby-images/7d0a2/7d0a2da9d8e4c1026868d15b001ac79095fd6f57" alt=""
?
Object的顶端
?console.log(Object.prototype.__proto__ === null);
?data:image/s3,"s3://crabby-images/4adee/4adee6499c3b7644e38fe92c0f9b3f6108edcced" alt=""
?
最终的原型链
data:image/s3,"s3://crabby-images/ecbbf/ecbbf0e53c2bba83fb5e745aa534240c0d258583" alt=""
下一章:JavaScript 进阶第六章(this与函数的调用模式 )
?
|