JS部分总结ing

//作用域 + 闭包
1.js闭包:一个访问了自由变量的函数就是闭包 (自由变量:垮了自己的作用域的变量) => 闭包是个函数,他访问了自由变量
2.函数变量提升:现在AO中找,找不到再去GO找(GO:global object 全局变量, AO:Activation Object 执行期上下文) => 显示从函数里找,找不到去外面找
3.函数是JS的第一公民
4.函数作用域[[scope]]:
运行期上下文:当函数执行时,会创建一个名为执行期上下文的内部对象,它定义了一个函数执行时的环境。函数每次执行时其上下文是唯一的,多次调用一个函数会生成多个执行期上下文,当函数调用完,其对应的执行期上下文被销毁。查找变量时则从作用域的顶端开始查找。
在这里插入图片描述
在这里插入图片描述

//原型 + 原型链
1.构造函数 / 实例对象
2.instanceof 内部实现机制
3.new做了啥?
在这里插入图片描述

//异步 + 单线程
1.js是一直是单线程的,浏览器才是实现异步的那个家伙

//深浅拷贝
1.深拷贝:深入不变,自食其力, number,string,boolean,null,undefined,symbol,BigInt 七类
2.浅拷贝:跟着变,

//js中的this
1.在函数中直接使用则是window,函数作为对象直接调用,则指向对象
在这里插入图片描述

//宏任务,微任务
1.宏任务:
2.微任务:
3.js 是单线程执行的,js中的任务按顺序一个一个的执行,但是一个任务耗时太长;
那么后面的任务就需要等待,为了解决这种情况,将任务分为了同步任务和异步任务;
而异步任务又可以分为微任务和宏任务。
4.js: 同步 + 异步 (宏任务 + 微任务)
5.同步:在一个线程上(主栈/主任务队列)同一个时间只能做一件事情,当前事情完成才能进行下一个事情(先把一个任务进栈执行,执行完成,在把下一个任务进栈,上一个任务出栈…)
异步:在主栈中执行一个任务,但是发现这个任务是一个异步的操作,我们会把它移除主栈,放到等待任务队列中(此时浏览器会分配其它线程监听异步任务是否到达指定的执行时间),如果主栈执行完成,监听者会把到达时间的异步任务重新放到主栈中执行…
6.同步 + 异步 谁先执行 , 宏任务 + 微任务谁先执行

//堆,栈

//vue生命周期

//JS概括
在这里插入图片描述

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值