web前端开发第二阶段——预解析机制/函数称呼/递归函数/闭包函数/浏览器垃圾回收机制

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_43151638/article/details/102720299

预解析机制

浏览器先把要执行的代码,预先排列一个顺序,顺序排列完后在执行代码
1、先找到代码里面的所有var 变量,把var变量提前(最前面)赋值不提前
2、找到要声明的函数
3、把剩下的代码从上往下的顺序执行

函数称呼

1、有名函数
function fn(){}
2、匿名函数(没有名字的函数)直执行函数
作用: 可以减少变量名冲突
写法:

(function(){
})

调用:

(function(){
})()

性能优化,少些全局变量;全局变量,函数不清空内存

全部字符拼接不友好

递归函数:函数自己调用自己

ps:避免出现死循环

闭包函数:在函数里面嵌套一个函数

用他的漏洞做功能
特点:在调用闭包函数时,如果闭包函数里面没有变量或者参数,在使用这个变量或参数时,会沿着作用链找变量或参数,找到后放到自己的作用域里面,不会被浏览器的垃圾回收机制清空。

闭包函数的内存泄露
形成闭包函数:函数执行完不被销毁,(可以通过赋给变量)

浏览器的垃圾回收机制

部分浏览器以此方式进行垃圾回收,当变量进入执行环境(函数中声明变量,执行时)的时候,垃圾回收器将其标记为“进入环境”,当变量离开环境的时候(函数执行结束)将其标记为“离开环境”,在离开环境之后还有的变量则是需要被删除的变量。

猜你喜欢

转载自blog.csdn.net/qq_43151638/article/details/102720299
今日推荐