js 深度学习(八)

原型及原型链

prototype是function对象的一个属性 它也是一个对象

prototype是定义构造函数构造出的每个对象的公共祖先

所以被该构造函数构造出来的对象 都可以继承原型上的属性和方法

自己有的属性不会去原型上找

方法写在原型上 属性写在构造函数内部

__proto__是实例化以后的结果 属于实例化对象而不是构造函数

conststuctor指向构造函数本身 构造函数可以修改

bash 复制代码
插件写法:隔绝变量
立即执行函数加分号
;(function(){
var a = 1;
function Test(){
}
window.Test = Test;
})();
var test = new Test();

原型链的顶端是Object.prototype

普通函数不设置返回值 默认返回undefined,构造函数默认返回this

原型的原型是由object构造的

bash 复制代码
Object.create(对象,null)//创建对象 自定义原型 把别的对象作为自己的原型继承
Object.create(Obj.prototype) === new Obj()
Object.create(null) //纯粹空对象 连构造函数和原型都没有
//不是所有的对象都继承object.prototype
object.__proto__ //可以更改但是不可以自己指定 自己指定的无法访问属性
bash 复制代码
undefined null toString() //报错
// 原始值没有属性 数字可以是因为包装类
bash 复制代码
undefined null toString() //报错
// 原始值没有属性 数字可以是因为包装类
原型方法重写 object不能实现 所以重写
Number.prototype.toString.call(1) //"1"
Object.prototype.toString.call(1) // "[object Number]"
bash 复制代码
call // 改变this指向 
Car.call(newCar,'Benz','red')
Car.apply(newCar,['Benz','red'])
相关推荐
洛阳泰山几秒前
Java实现周易六爻自动排盘:根据起卦的公历时间换算农和干支时间,推算日柱空亡(旬空)
java·开发语言·周易·六爻·算卦
AY呀5 分钟前
# 🌟 JavaScript原型与原型链终极指南:从Function到Object的完整闭环解析 ,深入理解JavaScript原型系统核心
前端·javascript·面试
氤氲息8 分钟前
鸿蒙 ArkTs 的WebView如何与JS交互
javascript·交互·harmonyos
叫我詹躲躲13 分钟前
别再用mixin了!Vue3自定义Hooks让逻辑复用爽到飞起
javascript·vue.js
Smile丶凉轩19 分钟前
C++ 高性能内存池面试题总结
开发语言·c++
豆苗学前端19 分钟前
HTML + CSS 终极面试全攻略(八股文 + 场景题 + 工程落地)
前端·javascript·面试
世转神风-33 分钟前
qt-pro文件名词解释
开发语言·qt
珑墨40 分钟前
【迭代器】js 迭代器与可迭代对象终极详解
前端·javascript·vue.js
Fantastic_sj1 小时前
[代码例题] var 和 let 在循环中的作用域差异,以及闭包和事件循环的影响
开发语言·前端·javascript
JANG10241 小时前
【Linux】常用指令
linux·服务器·javascript