Web前端最全React Native 新架构(1),20道前端工程师面试必题目
总结一下面试前要精心做好准备,简历上写的知识点和原理都需要准备好,项目上多想想难点和亮点,这是面试时能和别人不一样的地方。
另有就是表现出自己的谦虚好学,以及对于未来持续进阶的规划,企业招人更偏爱稳固的人。
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
万事开头难,但是步伐员这一条路坚持几年后发展空间还是非常大的,一切重在坚持。
为了帮助大家更好更高效的准备面试,特别整理了《前端工程师面试手册》电子稿文件。
https://i-blog.csdnimg.cn/blog_migrate/60cb7c1b74474d7e5a5546cc285d7586.png
https://i-blog.csdnimg.cn/blog_migrate/8bb05c431555e98a9a843fe5fa668b9d.png
前端面试题汇总
https://i-blog.csdnimg.cn/blog_migrate/0e3e725c2b52c0d80cc380a18efe5fd9.png
JavaScript
https://i-blog.csdnimg.cn/blog_migrate/9320ddadc20aa9901f6059017c06bce9.png
性能
https://i-blog.csdnimg.cn/blog_migrate/80f436616b3456a1e3fabb96c355d408.png
linux
https://i-blog.csdnimg.cn/blog_migrate/9ddd13c78eef6f7bdd7d52f641a2ff76.png
前端资料汇总
https://i-blog.csdnimg.cn/blog_migrate/76efd569a51c5aef0b8848e79c9e7dd7.png
前端工程师岗位缺口一直很大,符合岗位要求的人越来越少,所以学习前端的小伙伴要留意了,一定要把技能学到扎实,做有含金量的项目,如许在找工作的时候无论碰到什么情况,题目都不会大。
UI thread 拿到消息后,同样先反序列化,然后根据所给布局信息,进行绘制。
从上面过程可以看到三个线程的交互都是要通过Bridge,因此瓶颈也就在此。
Bridge三个特点:
[*] 异步。这些消息队列是异步的,无法保证处理变乱。
[*] 序列化。通过JSON格式来传递消息,每次都要经历序列化和反序列化,开销很大。
[*] 批处理。对Native调用进行排队,批量处理。
异步设计的利益是不阻塞,这种设计在大部门情况下性能满足需求,但是在某些情况下就会出题目,好比瀑布流滚动。
当瀑布流向下滑动的时候,需要发请求给服务端拿数据进行下一步渲染。
滚动变乱发生在UI thread,然后通过Bridge发给JS thread。JS thread 监听到消息后发请求,服务端返回数据,再通过Bridge返回给Native进行渲染。由于都是异步,就会出现空缺模块,导致性能题目。
从上面可以看出,性能瓶颈主要是存在JS线程和Native有交互的情况,如果不存在交互,RN的性能良好。
因此,对于RN的优化,主要集中在Bridge上,有下面3个原则:
[*] JS和Native端不通信。最彻底的方式,消息不走Bridge。
[*] JS和Native减少通信。在两端无法避免的情况下,尽量通信减少次数。好比多个请求归并成一个。
[*] 较少JSON的大小。好比图片转为Base64会导致传输数据变大,用网络图片取代。
RN里面可以通过MessageQueue来监听Bridge通信,主要代码如下
import MessageQueue from ‘react-native/Libraries/BatchedBridge/MessageQueue.js’;
const spyFunction = (msg) => {
console.log(msg);
};
MessageQueue.spy(spyFunction);
下面是监听到的信息
https://i-blog.csdnimg.cn/blog_migrate/147e6b66923c2d5748c29d12bf6e81d8.jpeg
新架构
FB团队渐渐意识到了这些题目,同时也受到Flutter的压力,在2018年提出了新架构
https://i-blog.csdnimg.cn/blog_migrate/8a3ac0a9c68d8039e757567c6e09a349.png
主要有JSI、Fabric、TurboModules、CodeGen、LeanCode构成。
JSI
JSI是整个架构的核心和基石,所有的一切都是创建在它上面。
JSI是Javascript Interface的缩写,一个用C++写成的轻量级框架,它作用就是通过JSI,JS对象可以直接得到C++对象(Host Objects)引用,并调用对应方法。
另外JSI与React无关,可以用在任何JS 引擎(V8,Hermes)。
有了JSI,JS和Native就可以直接通信了,调用过程如下:
JS->JSI->C+±>ObjectC/Java
自此三个线程通信再也不需要通过Bridge,可以直接知道对方的存在,让同步通信成为现实。详细的用法可以看 官方例子。
另外一个利益就是有了JSI,JS引擎不再局限于JSC,可以自由的更换为V8,Hermes,进一步进步JS解析实行的速率。
Fabric
Fabric是整个架构中的新UI层,包括了新架构图中的renderer和shadow thread。
下图是旧的通信模型。
https://i-blog.csdnimg.cn/blog_migrate/54a19e4ae0798c89374f83c305660430.png
三个线程通过Bridge异步通信,数据需要拷贝多份。
有了JSI以后,JS可以直接掉调用其他线程,实现同步通信机制。另外数据可以直接引用,不需要拷贝,于是就酿成了下面新的通信模式.
https://i-blog.csdnimg.cn/blog_migrate/48dab1739a871096da4cfee2c2d60811.png
除了同步能力,直接引用,另外一个利益是Fabric如今支持渲染优先级好比React的Concurrent和Suspense模式
下面两张图是从启动到渲染阶段,加入Fabric前后的变化。
https://i-blog.csdnimg.cn/blog_migrate/80829c0299e8b1037ba411e99b8746f9.png
改造为Fabric之后
https://i-blog.csdnimg.cn/blog_migrate/62be0ee2da578960ee539bcfd522c4c7.png
TurboModules
TurboModules主要和原生应用能力相关,对应新架构图上的Native Modules,这部门的优化是:
[*] 通过JSI,可以让JS直接调用Native模块,实现一些同步操纵。好比调用摄像头能力。
[*] Native模块懒加载。之前RN框架启动的时候会加载所有Native模块,导致启动慢,时间久。如今有了TurboModules后,可以实现按需加载,减少启动时间,进步性能。
CodeGen
通过CodeGen,自动将Flow或者Ts等有静态类型的JS代码翻译成Fabric和TurboModules使用的原生代码。
Lean Core
这部门主要是包的瘦身,从前所有的包都放在RN核心工程里面。如今RN核心只保留必要的包,其他都移到react-native-community 或者拆出单独的组件,好比Webview和AsyncStore。
Vue 面试题
1.Vue 双向绑定原理
2.形貌下 vue 从初始化页面–修改数据–刷新页面 UI 的过程?
3.你是如何明白 Vue 的相应式系统的?
4.虚拟 DOM 实现原理
5.既然 Vue 通过数据劫持可以精准探测数据变化,为什么还需要虚拟 DOM 进行 diff 检测差别?
6.Vue 中 key 值的作用?
7.Vue 的生命周期
8.Vue 组件间通信有哪些方式?
9.watch、methods 和 computed 的区别?
10.vue 中怎么重置 data?
11.组件中写 name 选项有什么作用?
12.vue-router 有哪些钩子函数?
13.route 和 router 的区别是什么?
14.说一下 Vue 和 React 的熟悉,做一个简单的对比
15.Vue 的 nextTick 的原理是什么?
16.Vuex 有哪几种属性?
17.vue 首屏加载优化
18.Vue 3.0 有没有过相识?
19.vue-cli 替我们做了哪些工作?
https://i-blog.csdnimg.cn/blog_migrate/ad20b37548979a0f5bfb6188ea852f27.png
如果你以为对你有帮助,可以戳这里获取:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
14.说一下 Vue 和 React 的熟悉,做一个简单的对比
15.Vue 的 nextTick 的原理是什么?
16.Vuex 有哪几种属性?
17.vue 首屏加载优化
18.Vue 3.0 有没有过相识?
19.vue-cli 替我们做了哪些工作?
[外链图片转存中…(img-VZwQblqw-1715860676992)]
如果你以为对你有帮助,可以戳这里获取:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]