You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Floats, absolutely positioned elements, block containers (such as inline-blocks, table-cells, and table-captions) that are not block boxes, and block boxes with 'overflow' other than 'visible' (except when that value has been propagated to the viewport) establish new block formatting contexts for their contents.
关于【Step-By-Step】
6. 节流(throttle)函数的作用是什么?有哪些应用场景,请实现一个节流函数。(2019-05-27)
节流函数的作用
节流函数的作用是规定一个单位时间,在这个单位时间内最多只能触发一次函数执行,如果这个单位时间内多次触发函数,只能有一次生效。
举例说明:小明的妈妈和小明约定好,如果小明在周考中取得满分,那么当月可以带他去游乐场玩,但是一个月最多只能去一次。
这其实就是一个节流的例子,在一个月的时间内,去游乐场最多只能触发一次。即使这个时间周期内,小明取得多次满分。
节流应用场景
1.按钮点击事件
2.拖拽事件
3.onScoll
4.计算鼠标移动的距离(mousemove)
节流函数实现
时间戳和定时器的方式都没有考虑最后一次执行的问题,比如有个按钮点击事件,设置的间隔时间是1S,在第0.5S,1.8S,2.2S点击,那么只有0.5S和1.8S的两次点击能够触发函数执行,而最后一次的2.2S会被忽略。
使用很简单:
7. 说一说你对JS执行上下文栈和作用域链的理解?(2019-05-28)
在开始说明JS上下文栈和作用域之前,我们先说明下JS上下文以及作用域的概念。
JS执行上下文
执行上下文就是当前 JavaScript 代码被解析和执行时所在环境的抽象概念, JavaScript 中运行任何的代码都是在执行上下文中运行。
执行上下文创建过程中,需要做以下几件事:
作用域
作用域负责收集和维护由所有声明的标识符(变量)组成的一系列查询,并实施一套非常严格的规则,确定当前执行的代码对这些标识符的访问权限。—— 摘录自《你不知道的JavaScript》(上卷)
作用域有两种工作模型:词法作用域和动态作用域,JS采用的是词法作用域工作模型,词法作用域意味着作用域是由书写代码时变量和函数声明的位置决定的。(
with
和eval
能够修改词法作用域,但是不推荐使用,对此不做特别说明)JS执行上下文栈(后面简称执行栈)
执行栈,也叫做调用栈,具有 LIFO (后进先出) 结构,用于存储在代码执行期间创建的所有执行上下文。
以一段代码具体说明:
Global Execution Context
(即全局执行上下文)首先入栈,过程如下:伪代码:
作用域链
作用域链就是从当前作用域开始一层一层向上寻找某个变量,直到找到全局作用域还是没找到,就宣布放弃。这种一层一层的关系,就是作用域链。
如:
fn2作用域链 = [fn2作用域, fn1作用域,全局作用域]
8. 什么是BFC?BFC的布局规则是什么?如何创建BFC?(2019-05-29)
什么是BFC
BFC 是 Block Formatting Context 的缩写,即块格式化上下文。我们来看一下CSS2.1规范中对 BFC 的说明。
因此,如果想要深入的理解BFC,我们需要了解以下两个概念:
Box
Box 是 CSS 布局的对象和基本单位,页面是由若干个Box组成的。
元素的类型 和
display
属性,决定了这个 Box 的类型。不同类型的 Box 会参与不同的 Formatting Context。Formatting Context
Formatting Context 是页面的一块渲染区域,并且有一套渲染规则,决定了其子元素将如何定位,以及和其它元素的关系和相互作用。
Formatting Context 有 BFC (Block formatting context),IFC (Inline formatting context),FFC (Flex formatting context) 和 GFC (Grid formatting context)。FFC 和 GFC 为 CC3 中新增。
BFC布局规则
margin
属性决定。属于同一个BFC的两个相邻Box的margin会发生重叠【符合合并原则的margin合并后是使用大的margin】如何创建BFC
BFC的应用
1.防止 margin 重叠
两个div直接的
margin
是50px,发生了margin
的重叠。2.清除内部浮动
3.自适应多栏布局
9. let、const、var 的区别有哪些?(2019-05-30)
1.let/const 定义的变量不会出现变量提升,而 var 定义的变量会提升。
2.相同作用域中,let 和 const 不允许重复声明,var 允许重复声明。
3.cosnt 声明变量时必须设置初始值
4.const 声明一个只读的常量,这个常量不可改变。
这里有一个非常重要的点即是:复杂数据类型,存储在栈中的是堆内存的地址,存在栈中的这个地址是不变的,但是存在堆中的值是可以变得。有没有相当常量指针/指针常量~
一图胜万言,如下图所示,不变的是栈内存中 a 存储的 20,和 b 中存储的 0x0012ff21(瞎编的一个数字)。而 {age: 18, star: 200} 是可变的。思考下如果想希望一个对象是不可变的,应该用什么方法?
5.let/const 声明的变量仅在块级作用域中有效。而 var 声明的变量在块级作用域外仍能访问到。
在 let/const 之前,最早学习JS的时候,也曾被下面这个问题困扰:
期望:
a[0]() 输出 0 , a[1]() 输出 1 , a[2]() 输出 2 , ...
虽然后来知道了为什么,但是想要得到自己需要的结果,还得整个闭包,我...我做错了什么,要这么对我...
有了 let 之后,终于不要这么麻烦了。
美滋滋,有没有~
美是美了,但是总得问自己为什么吧~
var i
为什么输出的是 10,这是因为 i 在全局范围内都是有效的,相当于只有一个变量 i,等执行到a[6]()
的时候,这个 i 的值是什么?请大声说出来。再看 let , 我们说 let 声明的变量仅在块级作用域内有效,变量i是let声明的,当前的 i 只在本轮循环有效,所以每一次循环的 i 其实都是一个新的变量。有兴趣的小伙伴可以查看 babel 编译后的代码。
6.顶层作用域中 var 声明的变量挂在window上(浏览器环境)
7.let/const有暂时性死区的问题,即let/const 声明的变量,在定义之前都是不可用的。如果使用会抛出错误。
只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域,不再受外部的影响。
在代码块内,使用 let/const 命令声明变量之前,该变量都是不可用的,也就意味着 typeof 不再是一个百分百安全的操作。
10. 深拷贝和浅拷贝的区别是什么?如何实现一个深拷贝?(2019-05-31)
深拷贝和浅拷贝是针对复杂数据类型来说的。
深拷贝
浅拷贝
可以使用
for in
、Object.assign
、 扩展运算符...
、Array.prototype.slice()
、Array.prototype.concat()
等,例如:可以看出浅拷贝只最第一层属性进行了拷贝,当第一层的属性值是基本数据类型时,新的对象和原对象互不影响,但是如果第一层的属性值是复杂数据类型,那么新对象和原对象的属性值其指向的是同一块内存地址。来看一下使用
for in
实现浅拷贝。深拷贝实现
JSON.parse(JSON.stringify(obj))
是最简单的实现方式,但是有一点缺陷:1.对象的属性值是函数时,无法拷贝。
2.原型链上的属性无法获取
3.不能正确的处理 Date 类型的数据
4.不能处理 RegExp
5.会忽略 symbol
6.会忽略 undefined
RegExp
或者Date
类型,返回对应类型测试:
参考文章:
[1] https://www.ecma-international.org/ecma-262/6.0/#sec-completion-record-specification-type
[2] 【译】理解 Javascript 执行上下文和执行栈
[3] https://css-tricks.com/debouncing-throttling-explained-examples/
[4] mqyqingfeng/Blog#4
[5] https://www.cnblogs.com/coco1s/p/4017544.html
[6] https://www.cnblogs.com/wangfupeng1988/p/4000798.html
[7] https://www.w3.org/TR/2011/REC-CSS2-20110607/visuren.html#block-boxes
[8] mqyqingfeng/Blog#4
谢谢各位小伙伴愿意花费宝贵的时间阅读本文,如果本文给了您一点帮助或者是启发,请不要吝啬你的赞和Star,您的肯定是我前进的最大动力。https://github.com/YvetteLau/Blog
The text was updated successfully, but these errors were encountered: