1. 谈谈对js 作用域的理解:
官方回答:
js全局有全局可执行上下文, 每个函数调用时,有着函数的可执行上下文.
每个可执行上下文,都有着对于外部上下文的引用,外部上下文也有着对于外部的上下文词法作用域的引用=>就形成了作用域链
本人理解: 当在局部作用域中找一个值时,如果当前作用域中没有,就会往外部上一层的作用域中寻如果外部上一层的作用域中还是没有,那么就会继续往上找,一直找到全局作用域中.这个寻找的过程就称为作用域链
2.谈谈你对闭包的理解
闭包: 内部函数,访问了外部函数的变量,就可以形成闭包 闭包 = 函数 + 周围状态(环境的)的引用
闭包的作用: 实现数据私有化,提供操作
由于 count 是全局变量,极其容易被修改,但是在实际应用中,我们需要避免全局变量,所以我们需要对数据形成私有化,从而更好的提供操作数据的环境
在控制台我们修改了 count 的值, 然后在调用 此时 count 就显示已经加了102次 可是实际代码中只加了2次.所以我们当然不会希望数据轻而易举的被改变,所以我们需要用到闭包结构(我认为闭包是一种结构)
当我把count放在局部作用域中,此时count的值就不会轻易被改变了, 这里的return f1就相当于把 f1这个函数给返回出去方便应用 所以result === f1了 因为fn的返回值是f1嘛 这样就形成了闭包结构
闭包的理解误区
误区1:闭包会造成内存泄漏。内存泄漏是指:我们再也用不到(无法访问到)的变量,依然占着内存空间。而闭包内部的变量是可以访问到呀,所以不应该归到内存泄漏中去。
误区2:闭包比较复杂,写代码尽量别写闭包。以现在前端代码的复杂程度,没有闭包的代码决计不可能发生!
误区3:只有js中才有闭包。这个就更离谱了。隔壁的python兄弟,c#兄弟会笑话我们的。 闭包并不是针对某一特定语言的概念,而是一个通用的概念。除了在各个支持函数式编程的语言中,我们会接触到它。一些不支持函数式编程的语言中也能支持闭包(如java8之前的匿名内部类)。
3, 谈谈你对原型链的理解
在JavaScript 中, 每个对象中都有一个_proto_属性,这个属性指向了当前对象的构造函数的原型.对象可通过自身的_proto_属性与它的构造函数的原型对象连接起来, 而因为它的原型对象也有_proto_,因此这样就串联形成一个链式结构,也就是我们称为的原型链
4 构造函数,实例对象,原型对象之间的关系