NIUCLOUD是一款SaaS管理后台框架多应用插件+云编译。上千名开发者、服务商正在积极拥抱开发者生态。欢迎开发者们免费入驻。一起助力发展! 广告
# 大厂高级前端面试题答案 ## 阿里 **使用过的koa2中间件** [www.jianshu.com/p/c1e0ca3f9…](https://link.juejin.im/?target=https%3A%2F%2Fwww.jianshu.com%2Fp%2Fc1e0ca3f9764) **koa-body原理** [blog.csdn.net/sinat\_17775…](https://link.juejin.im/?target=https%3A%2F%2Fblog.csdn.net%2Fsinat_17775997%2Farticle%2Fdetails%2F82898312) **有没有涉及到Cluster** [nodejs.cn/api/cluster…](https://link.juejin.im/?target=http%3A%2F%2Fnodejs.cn%2Fapi%2Fcluster.html) **介绍pm2** PM2是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,如性能监控、自动重启、负载均衡等,而且使用非常简单 **master挂了的话pm2怎么处理** [www.cnblogs.com/Yanss/p/101…](https://link.juejin.im/?target=https%3A%2F%2Fwww.cnblogs.com%2FYanss%2Fp%2F10168359.html) **如何和MySQL进行通信** node为例 [www.fly63.com/article/det…](https://link.juejin.im/?target=http%3A%2F%2Fwww.fly63.com%2Farticle%2Fdetial%2F1343) **React声明周期及自己的理解** [react.docschina.org/docs/state-…](https://link.juejin.im/?target=https%3A%2F%2Freact.docschina.org%2Fdocs%2Fstate-and-lifecycle.html%23%25E5%25B0%2586%25E7%2594%259F%25E5%2591%25BD%25E5%2591%25A8%25E6%259C%259F%25E6%2596%25B9%25E6%25B3%2595%25E6%25B7%25BB%25E5%258A%25A0%25E5%2588%25B0%25E7%25B1%25BB%25E4%25B8%25AD) **如何配置React-Router** [react-china.org/t/react-rou…](https://link.juejin.im/?target=http%3A%2F%2Freact-china.org%2Ft%2Freact-router4%2F15843) **路由的动态加载模块** [blog.csdn.net/qq\_35484341…](https://link.juejin.im/?target=https%3A%2F%2Fblog.csdn.net%2Fqq_35484341%2Farticle%2Fdetails%2F80506297) **服务端渲染SSR** 以react 服务端渲染为例 [www.colabug.com/3873468.htm…](https://link.juejin.im/?target=https%3A%2F%2Fwww.colabug.com%2F3873468.html) **介绍路由的history** History 对象最初设计来表示窗口的浏览历史。但出于隐私方面的原因,History 对象不再允许脚本访问已经访问过的实际 URL。唯一保持使用的功能只有 back()、forward() 和 go() 方法。window.history.pushState(stateObject,title,url ) ~~~ 将当前URL和history.state加入到history中,并用新的state和URL替换当前,不会造成页面刷新。 --参数解释 stateObject //与要跳转到的URL对应的状态信息,没有特殊的情况下可以直接传{} title //现在大多数浏览器不支持或者忽略这个参数,我们在用的时候建议传一个空字符串 url //这个参数提供了新历史纪录的地址,它不一定要是绝对地址,也可以是相对的,不可跨域复制代码 ~~~ window.history.replaceState(stateObject,title,url) ~~~ 用新的state和URL替换当前,不会造成页面刷新。 --参数解释 stateObject //与要跳转到的URL对应的状态信息,没有特殊的情况下可以直接传{} title //现在大多数浏览器不支持或者忽略这个参数,我们在用的时候建议传一个空字符串 url //这个参数提供了新历史纪录的地址,它不一定要是绝对地址,也可以是相对的,不可跨域执 行完之后,我们发现不能回退了,是不是就跟window.location.replace()实现同样的效果了复制代码 ~~~ 原文:[blog.csdn.net/qq\_34645412…](https://link.juejin.im/?target=https%3A%2F%2Fblog.csdn.net%2Fqq_34645412%2Farticle%2Fdetails%2F80087372) react-router 中的history [segmentfault.com/a/119000001…](https://link.juejin.im/?target=https%3A%2F%2Fsegmentfault.com%2Fa%2F1190000010251949) **介绍Redux数据流的流程** ![]() **Redux如何实现多个组件之间的通信,多个组件使用相同状态如何进行管理** 请使用状态提升的方式在多个组件之间共享数据 切记维持应用单向数据流和数据唯一来源原则。 react 小例子 [juejin.im/post/5b471a…](https://juejin.im/post/5b471a5de51d4519873f2c07) **多个组件之间如何拆分各自的state,每块小的组件有自己的状态,它们之间还有一些公共的状态需要维护,如何思考这块** 状态提升,找到容器组件和展示组件,保证唯一数据源和单向数据 对于组件的拆分还要做到高内聚低耦合 [react.docschina.org/docs/liftin…](https://link.juejin.im/?target=https%3A%2F%2Freact.docschina.org%2Fdocs%2Flifting-state-up.html) **使用过的Redux中间件** redux-thunk redux-logger 图解浏览器的工作原理 [mp.weixin.qq.com/s/X4...](https://link.juejin.im/?target=https%3A%2F%2Fmp.weixin.qq.com%2Fs%2FX4yAFZBNLwaDUFYaR0Cn5g) [原文链接]([https://juejin.im/post/5c6292566fb9a049c64453ca](https://juejin.im/post/5c6292566fb9a049c64453ca))