最新公告
  • 欢迎您光临网站无忧模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 前端面试(JS部分)

    正文概述 掘金(落月誻雪)   2021-01-02   441
    1. 闭包
    • 什么是闭包?
      • 密闭的容器,类似于set,map容器,存储数据的
      • 闭包是一个对象,存储是键值对的形式
    • 闭包的产生
    我将会从js的垃圾回收,作用域链,代码执行环境讲起
    
    首先,产生闭包的条件是,函数嵌套,内部函数引用了外部函数的局部变量,这样导致了这个变量在内存上无法被回收,由此产生了所谓的闭包
    
    那么这个变量为什么无法被回收了呢,这就要从js的垃圾回收谈起,js代码在执行时,会进入执行环境
    而垃圾回收会根据代码是处于进入环境还是退出环境状态,对于处于进入环境状态的代码,系统认为它可能马上被使用,是绝对不会去回收它的,所以它会一直在内存上,也就说,闭包是因为代码处于执行环境,所以不会被回收
    
    可是为什么代码会在执行环境呢,外部函数代码明明已经结束了,它的变量应该被释放呀
    这就跟作用域链有关了,内部函数使用变量时,先在当前环境查找,没有的话,会从包含环境内找,此时,它在外部的包含环境中找到了,所以它就拿过来用,我们之前说的当代码进入执行环境时,是不会被回收的,而外部函数的变量,此时正在被使用(作用域链的原理),所以这个变量仍然处于执行环境,所以它是不会被回收的,也就保存在了内存上。
    
    以上就是闭包产生的原因了
    也因此,闭包是一把双刃剑,它延长了变量的生命周期,但是它也会造成内存泄漏,因为一直不回收
    
    1. 原型/原型链
    • 原型是一个对象,所以也称原型对象prototype
      • 解决函数内存浪费的问题
      • 共享方法
    • 对象原型 __proto__
      • 每个对象身上,系统会自动为其添加一个__proto__,它指向构造函数的原型对象prototype,所以对象可以访问原型对象上的方法
      • obj.proto === Object.prototype 返回true
    • constructor 构造函数
      • prototype和__proto__都有一个constructor属性,它指回这个对象的构造函数
    obj.prototype = {
     constructor: 构造函数,
     func(){}
    }
    
    • 原型对象、对象原型、构造函数、实例对象之间的联系,它们构成了原型链

    前端面试(JS部分)

    • JS的查找规则
      • 按照原型链的机制查找
      • 冲突时采取就近原则
    • 原型对象的this指向
      • 构造函数的this指向实例化对象
      • 原型对象的this指向调用该原型对象方法的实例对象
      • 总结来说就是谁调用指向谁

    下载网 » 前端面试(JS部分)

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元