- vue的双向绑定原理
- Object.defineProperty的缺点
1.Object.defineProperty无法监控到数组下标的变化,导致通过数组下标添加元素,不能实时响应;
2.Object.defineProperty只能劫持对象的属性,从而需要对每个对象,每个属性进行遍历,如果,属性值是对象,还需要深度遍历。Proxy可以劫持整个对象,并返回一个新的对象。
3. Proxy不仅可以代理对象,还可以代理数组。还可以代理动态增加的属性。
https://github.com/Advanced-Frontend/Daily-Interview-Question/issues/90
3. 讲讲闭包
链接
4. 闭包有哪些危害
-
f有a和b方法吗 讲一下这个的原型链
有a方法 没有b方法 -
箭头函数和普通函数有哪些不同,this指向,箭头函数有原型对象吗
58
-
讲一下作用域和作用域链
作用域 -
讲一下强缓存和协商缓存的状态码,它们的相同点在什么地方。不同点在什么地方
https://blog.csdn.net/wsymcxy/article/details/82154397 -
讲一下原型链和原型对象
-
讲一下js的全局作用域
应该是面试官在提醒我 作用域从全局作用域 函数作用域 块级作用域这三块来说 -
讲一下垃圾回收
红宝书p78
js具有垃圾自动收集机制,也就是执行环境会负责管理代码执行过程中所使用的内存。垃圾收集机制的原理很简单。找出那些不在继续使用的变量,然后释放其占用的内存。
js中最常用的垃圾回收方式就是标记清除。当变量进入环境时,例如,在一个函数中声明一个变量,就将这个变量标记为"进入环境",从逻辑上讲,永远不能释放进入环境变量所占用的内存,因为只要执行流进入相应的环境,就可能会用到它们。而当变量离开环境时,则将其标记为"离开环境"。`
function test(){
var a = 10; //被标记"进入环境"
var b = "hello"; //被标记"进入环境"
}
test(); //执行完毕后之后,a和b又被标记"离开环境",被回收
语言引擎有一张"引用表",保存了内存里面所有资源(通常是各种值)的引用次数。如果一个值的引用次数是0,就表示这个值不再用到了,因此可以将这块内存释放。引用计数的含义是跟踪记录每个值被引用的次数。当声明了一个变量并将一个引用类型值赋给该变量时,则这个值的引用次数就是1,如果同一个值又被赋给另一个变量,则该值的引用次数加1。相反,如果包含对这个值的引用的变量又取得了另外一个值,则这个值的引用次数减1,当这个值的引用次数为0时,则说明没有办法再访问这个值了,因此就可以将其占用的内存空间回收回来。
let aa = [] // 数组[]引用1次
let bb = aa // 数组引用2次
bb = null // 释放内存,引用还剩下1次,即变量aa的引用还存在
面试官评价:基础概念不是很清楚 估计又要凉了
加油变强