JS高级-原型和执行上下文栈

typeof 返回数据类型的字符串表达式 (小写 number string…)
instanceof 返回的是布尔值

赋值运算:
将等号右边变量的值赋值给等号左边的变量
这个值可能是一般的数据,可能是一个地址数据

栈:存放全局变量和局部变量
堆:存放对象


原型对象

  1. 函数的显式原型默认是一个空的Object实例对象(但Object不满足)
console.log(Object.prototype instanceof Object)//false
console.log(Function.prototype instanceof Object)//true
  1. 实例对象的隐式原型等于构造函数的显式原型
  2. 函数既有显式原型,也有隐式原型(因为所有函数是通过new Function创建的,也就是说所有函数都是Function的实例,包括Function本身)
  3. 所有函数的隐式原型都是一样的,都指向Function.prototype
  4. functon Object()的隐式原型指向Function.prototype
  5. function Function()的隐式原型指向Function.prototypeFuntion = new Function()
  6. Object的原型对象是原型链的尽头
console.log(Object.prototype.__proto__)//null

原型链_属性问题

  1. 读取对象的属性值时,会自动到原型链中查找
  2. 设置对象的属性值时,不会查找原型链,如果当前对象中没有此属性,则直接添加此属性并设置其值
  3. 方法一般定义在原型中,属性一般通过构造函数定义在对象本身上

instanceof探索

表达式:A instanceof B
如果B函数的显示原型对象在A对象的原型链上,则返回true,否则返回false
注意: Function函数是通过new自己产生的实例

console.log(Object instanceof Function) //true
console.log(Object instanceof Object)//true
console.log(Function instanceof Object)//true
console.log(Function instanceof Function)//true

执行上下文和执行上下文栈

执行上下文

  1. 全局执行上下文
    在执行全局代码前将window确定为全局执行上下文
  • 先有变量提升, 再有函数提升
  1. 函数执行上下文
    在函数调用的时候产生函数执行上下文

执行上下文栈
栈的特点:后进先出
用来管理产生的多个执行上下文

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值