浏览器底层的渲染机制

一 浏览器打开页面会把页面中的内容自上而下的执行
二 浏览器想要执行代码会提供一个代码执行的环境,我们把这个环境叫做ECStack(Exection Context Stack 执行环境栈)=》栈内存Stack
(1)内存的概念
Stack:栈内存
Heap:堆内存
所谓栈堆内存就是在计算机内存中开辟出来的用于执行和存储代码的
三 最开始执行的是全局代码,所以会形成一个EC(GLOBAL)的全局执行上下文,在栈内存中执行全局代码
四 在EC(GLOBAL)中又有一个VO(GLOBAL)对象用于存储全局的变量和基本数据类型值
举个例子:let a=12;
1 先创建一个值12(基本数据类型存储在栈内存中)
2 创建一个变量a存储在VO(GLOBAL)中
3 让变量a与值12相关联
在这里插入图片描述
五 引用数据类型结构复杂,不能直接存储在栈内存中,需要单独开辟空间来存储,这个空间就叫做堆内存
举个例子
let n={name:’'小妹}
let m=n;
m.name=‘小红’
console.log(n.name);结果是小红
由于=后面是引用类型,所以会在将该类型的键与值存储在堆内存中,每一个堆内存有一个16进制的地址,把该地址存到栈内存中,然后将创建的变量与栈内存中的地址相关联
六 对象的属性如果为引用类型,则会转化成字符串,数字0和字符串’0’一样,对象转字符串都是{object,object}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值