Vue2面试题:说一下虚拟DOM的原理?
2024-01-08 10:20:28
? ? 虚拟dom是对真实dom的抽象,本质是JS对象
? ? 在生成真实DOM之前,vue会把模板编译为一个虚拟dom,当里面某个DOM节点发生变动时,通过diff算法对比新旧虚拟DOM,发现不一样的地方直接修改在真实的DOM上
? ? 优点:?
? ? ? ? 可以减少DOM操作
? ? ? ? 可以跨平台渲染
? ? 缺点:
? ? ? ? 严重依赖打包工具
? ? ? ? 节点规模过大时,虚拟DOM的稳定性不如原生DOM
vue的模板编译过程:
? ? 1、获取到template
? ? 2、template 转 AST树
? ? ? ? AST树:
? ? ? ? ? ? 抽象语法树(一个对象的格式)
? ? ? ? ? ? 源代码的抽象语法结构的树状描述
? ? ? ? ? ? 用于将vue的指令、语法等 转为 源代码的抽象语法结构
? ? 3、AST树 转 render函数
? ? ? ? render函数:
? ? ? ? ? ? 返回包含_c、_v、_s函数的字符串
? ? 4、执行render函数 转 虚拟DOM
? ? 5、执行patch方法,通过diff算法对比新旧虚拟DOM,打补丁,生成真实DOM
文章来源:https://blog.csdn.net/m0_74802419/article/details/135396785
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!