中级前端工程师要回的知识

1.什么是函数柯里化?

是把接受多个参数的函数变换成接受一个单一参数的函数,是典型的闭包函数

2.call、apply、bind区别?

相同点:

作用一致、都是修改this的指向。

不同点:

(1)传参方式不同,call()是按照顺序传参,apply()是通过数组/伪数组传参。

(2)执行机制不同,call()和apply()是立即执行函数,bind()不会立即执行函数,而是会返回一个修改过this的新函数。

call(修改后的this,形参1,形参2...)

apply(修改后的this,/伪数组)

bind(修改后的this) bind不会立即执行函数,而是返回一个修改之后的函数。

3.说说Event Loop.

首先js是单线程,js执行程序的过程中有优先级之分,会先执行js线程的同步任务,然后再执行微任务(promise.then,process.nextTick、Object.observe、MutationObserver),最后执行宏任务script、setTimeOut、setInterval、setImmediate

经典例子:

setTimeout(function(){
    console.log(1)
});
new Promise(function(resolve){
    console.log(2);
    resolve();
}).then(function(){
    console.log(3)
});
console.log(4);
new Promise(function(resolve){
    console.log(5);
    resolve();
}).then(function(){
    console.log(6)
});
setTimeout(function(){
    console.log(7)
});
function bar(){
    console.log(8)
    foo()
}
function foo(){
    console.log(9)
}
console.log(10)
bar()
    最终结果:2,4,5,10,8,9,3,6,1,7

vue响应式原理?(双向绑定原理)

响应式原理:采用数据劫持结合发布-订阅者模式的方式,通过Object.defineProperty()来劫持data里面各个属性的setter和getter,在数据变动的时候,触发set方法,检测到数据发生变化,会发布消息给订阅者,触发相应的监听回调,生成新的虚拟DOM树,视图更新。

性能优化方法?是否在项目中应用过一些优化方法?

说到性能优化,宏观上目前基本都被webpack 打包工具解决了,当我们使用webpack5的版本后,基本是开箱机带的功能,比如压缩js,和css,图片压缩,CDN=加速,按需加载。

项目中主要运用到的优化,主要有用性能优化api的意识,比如项目运用到的keep-alive缓存页面,增加访问速度,使用场景:A页面跳转B页面,需要纪录页面滚动的当前位置,某个页面具有多元素的页面,比如详情页面;节流防抖也算是性能优化,减少重绘和重徘,

这时面试官一般会问你会写节流防抖吗,什么是重绘和重徘:

    回流 render树中一部分或全部元素需要改变尺寸、布局、或着需要隐藏而需要重新构建,这个过程叫做回流 回流必将引起重绘 重绘 render树中一部分元素改变,而不影响布局的,只影响外观的,比如颜色。该过程叫做重绘 页面至少经历一次回流和重绘(第一次加载的时候)

判断对象为空的方法有?

JSON.stringfy(obj) === {}

object.keys(obj).length === 0

经验分享 程序员 微信小程序 职场和发展