深入JavaScript Day04 - 闭包、this的四种绑
作者:
望穿秋水小作坊 | 来源:发表于
2022-01-12 14:44 被阅读0次
一、闭包补充
1、闭包是如何导致内存泄漏的?如何解决?
- window【持有】了闭包函数,闭包函数【持有】了父级AO
- 后续不再使用闭包函数了,但是闭包函数持有的父级AO始终不能释放
-【解决方案】将window持有的闭包函数,指向null
data:image/s3,"s3://crabby-images/c3e79/c3e79a9dec1cc9267082b91e703defb33d4bb817" alt=""
image.png
2、借助Chrome的性能分析,来验证闭包的持有对象不释放问题?(思路很重要)
data:image/s3,"s3://crabby-images/1cd0d/1cd0d817e261b56bff646aaa6c76c8d0f6caa4ed" alt=""
image.png
3、如果闭包持有的父级AO中,仅仅使用name,而未使用age,那么age也会被持有吗?
- age不会被闭包持有
- 从浏览器的bugger模式可以看到
data:image/s3,"s3://crabby-images/be8e7/be8e79040264abcf6136557461f03d97bffe34df" alt=""
image.png
二、this的四种绑定情况
1、this指向其实是有点难知识点,那么为什么JavaScript开发中需要this呢?
- 有this的代码,将获得更好的灵活性、扩展性
- 比如下面代码,没有使用this,那么逻辑代码将和变量名绑定,耦合度就会很高,也不易扩展
data:image/s3,"s3://crabby-images/6ce42/6ce425e04c3ad109eb2bb7768080812c97d7db62" alt=""
image.png
2、浏览器中,在全局作用域下,this指向谁?
3、从下面代码,对于this有什么感悟?
data:image/s3,"s3://crabby-images/f247d/f247d48baeb8e9c7a50d1b228dc4cc076491e8d5" alt=""
image.png
- this的绑定和定义的位置(编写的位置)没有关系
- this是运行时被绑定的
4、默认绑定?
data:image/s3,"s3://crabby-images/850ae/850aee4dd4ecd92f9bedda25edb0a994304730ea" alt=""
image.png
5、隐式绑定?
data:image/s3,"s3://crabby-images/30a7f/30a7fed3ad40d390bb1bf06b73df47bdb013c7e6" alt=""
image.png
6、显示绑定?
data:image/s3,"s3://crabby-images/e8c13/e8c1303ba2af838b005a7d42b418baf129e476e3" alt=""
image.png
7、new绑定
data:image/s3,"s3://crabby-images/1d243/1d24334e8c2f4297bb17d904b694b35dc1fce13b" alt=""
image.png
8、call、apply、bind的区别?
data:image/s3,"s3://crabby-images/9d5a2/9d5a273dd1c33224456dc6431ece0ede9048bbca" alt=""
image.png
9、四种绑定规则的优先级?
data:image/s3,"s3://crabby-images/a5830/a5830226dcb4b437daf4910730fd5e36574f907a" alt=""
image.png
本文标题:深入JavaScript Day04 - 闭包、this的四种绑
本文链接:https://www.haomeiwen.com/subject/wpswcrtx.html
网友评论