没有虚拟DOM版本的vue(Vue Vapor)
前言
随着Svelte
和SolidJS
的流行,无虚拟DOM模式逐渐开始火了起来。vue
也推出了无虚拟DOM模式的版本,就是我们今天要讲的Vue Vapor
。
什么是Vue Vapor
Vue Vapor
是一个无虚拟DOM模式版本的vue
。这个仓库是2023年11月9日基于vuejs/core仓库(也就是vue3仓库)新建的,项目地址为 https://github.com/vuejs/core-vapor。Vue Vapor
目前还处于实验阶段
,不过你可以通过官方提供的Vue Vapor
演练场在线体验无虚拟DOM版本的vue
。playground演练场的地址为:https://vapor-repl.netlify.app。
目前Vue Vapor
只实现了vue3
中的部分功能,KeepAlive
、Teleport
等还未实现。详情查看官方的TODO:https://github.com/vuejs/core-vapor?tab=readme-ov-file#todo
如何使用Vue Vapor
对于使用者来说无虚拟DOM模式版本的vue
和目前的vue3
用法是一样的,vue
只是对内部实现进行了修改,对外暴露出的API
还是一样的,当然关于虚拟DOM相关的API在Vue Vapor
中没有了。
我们来看看一个demo,和目前vue3
写法是一样的:
<script setup>
import { ref } from 'vue'
const msg = ref('Hello World!')
</script>
<template>
<h1>{{ msg }}</h1>
<input v-model="msg" />
</template>
我们再来看看运行效果:
从*.vue
文件渲染到浏览器真实DOM的过程
我们先来看看目前版本的vue
是如何从一个*.vue
文件渲染到浏览器真实DOM?
目前的vue
是通过webpack
或者vite
等工具先将*.vue
文件编译成一个js
文件,js
文件中主要的就是render
函数。然后执行render
函数生成虚拟DOM,再调用浏览器的DOM API
根据虚拟DOM生成真实DOM挂载到浏览器上。
我们再来看看Vue Vapor
是如何从一个*.vue
文件渲染到浏览器真实DOM?
也是一样的首先通过webpack
或者vite
等工具先将*.vue
文件编译成一个js
文件,js
文件中主要的就是render
函数。然后执行render
函数后会直接调用浏览器的DOM API
生成真实DOM挂载到浏览器上。其实就是跳过了虚拟DOM的过程。
没有虚拟DOM后,Vue Vapor
如何实现响应式
我们先来看看demo编译后的js代码中的render
函数,下面是我简化后的代码:
function render(_ctx) {
_withDirectives(n2, [[_vModelText, () => _ctx.msg]])
_on(n2, "update:modelValue", $event => ((_ctx.msg) = $event))
_renderEffect(() => {
_setText(n1, _ctx.msg)
})
}
这里的n2
变量为input输入框dom元素,n1变量为显示msg
值的h1标签dom元素。明显可以看见render
函数中没有createElementVNode
等生成虚拟DOM的函数调用。
我们先来看看_withDirectives
函数,vue3
的withDirectives
函数的功能为给虚拟DOM增加自定义指令。我们这里没有虚拟DOM,所以这里是给真实DOM(input输入框)增加v-model
的指令。
我们再来看看下面 _on
函数,这里是让input
输入框监听一个名为update:modelValue
的事件,触发事件后会将上下文中的msg
变量的值更新为输入框中的输入值。
我们最后来看看_renderEffect
函数,看名字你可能已经猜出来了。这个函数和vue3
中的watchEffect
比较相似,会立即运行一个函数。并且追踪函数中用的的依赖,这里的依赖是msg
变量。当依赖的值变化时会再次执行这个函数。
这里的_setText(n1, _ctx.msg)
,实际就是执行了n1.textContent = _ctx.msg
。textContent
属性表示一个节点及其后代的文本内容,也可能通过给它赋值的方式删除它的所有子节点,并替换为一个具有给定值的文本节点,和innerText
功能比较相似。
当msg
变量的值变了后就会执行回调函数,在回调函数中会执行_setText
函数。_setText
函数会通过更新h1标签的textContent
属性让h1标签始终显示msg
变量最新的值,从而实现响应式。
总结
这篇文章介绍了Vue Vapor
,没有虚拟DOM版本的vue
。对于普通开发者来说Vue Vapor
其实和目前的vue3
没有什么区别,前提是不涉及虚拟DOM。只是vue
在内部实现上去掉了虚拟DOM,改为直接操作真实DOM。
如果我的文章对你有点帮助,欢迎关注公众号:【欧阳码农】,文章在公众号首发。你的支持就是我创作的最大动力,感谢感谢!
没有虚拟DOM版本的vue(Vue Vapor)的更多相关文章
- 使用虚拟 dom 渲染页面 《vue.js 设计与实现》
使用 js 对象描述 ui 更加灵活.假如我们要根据级别不同采用不同的标签.js 对象描述的话,只需要一个变量代表 h 标签即可. // 当变量改变时,标签也会变化. let level = 3 c ...
- 深入剖析虚拟DOM提升性能(Vue,React);
I.原始渲染方式(直接操作DOM): 1.state数据: 2.JSX模板: 3.数据 + 模板 相结合,生成真实的DOM来显示: 4.state发生改变: 5.数据 + 模板结合,生成真实的DOM来 ...
- vue 源码学习三 vue中如何生成虚拟DOM
vm._render 生成虚拟dom 我们知道在挂载过程中, $mount 会调用 vm._update和vm._render 方法,vm._updata是负责把VNode渲染成真正的DOM,vm._ ...
- Vue 虚拟Dom 及 部分生命周期初探
踏入前端,步入玄学 17年底至18年初附带做了vue的一些框架搭建,中途断断续续用了部分vue,时隔几个月后的工作又拾起vue,对于一些原理性的知识淡忘了,正值这段时间使用中遇到了一些坑,又拨了部分代 ...
- Vue源码探究-虚拟DOM的渲染
Vue源码探究-虚拟DOM的渲染 在虚拟节点的实现一篇中,除了知道了 VNode 类的实现之外,还简要地整理了一下DOM渲染的路径.在这一篇中,主要来分析一下两条路径的具体实现代码. 按照创建 Vue ...
- Vue如何用虚拟dom进行渲染view的
前提 vue版本:v2.5.17-beta.0 触发render vue在数据更新后会自动触发view的render工作,其依赖于数据驱动:在数据驱动的工作下,每一个vue的data属性都被监听,并且 ...
- Vue之虚拟DOM
一.真实DOM和其解析流程? 浏览器渲染引擎工作流程都差不多,大致分为5步,创建DOM树——创建StyleRules——创建Render树——布局Layout——绘制Painting 第一步,用HTM ...
- 从虚拟dom了解vue渲染函数
vue渲染函数就是render函数,他会返回一个VNode,VNode是一个js对象,是dom的映射 vue在介绍渲染函数那个章节看的不是很懂,所以想要彻底的理解渲染函数,首先需要了解vue的虚拟do ...
- Vue原理--虚拟DOM
为什么需要虚拟DOM? 如果对前端工作进行抽象的话,主要就是维护状态和更新视图,而更新视图和维护状态都需要DOM操作.其实近年来,前端的框架主要发展方向就是解放DOM操作的复杂性. 运行js的速度是很 ...
- vue虚拟DOM源码学习-vnode的挂载和更新流程
代码如下: <div id="app"> {{someVar}} </div> <script type="text/javascript& ...
随机推荐
- 华为云PB级数据库GaussDB(for Redis)解析第二期:Redis消息队列Stream的应用探讨
摘要:本文将对Stream的常用命令和应用场景进行介绍,并探讨原生Redis Stream消息队列的缺陷以及GaussDB(for Redis)提供的解决方案,供大家学习和选用. 华为云高斯Redis ...
- 华夏天信携手华为云开天aPaaS,打造安全、高效、节能的主煤流运输系统
摘要:基于开天aPaaS集成工作台,主煤流运输系统如何实现多源异构数据融合.皮带物料和人员违章的智能感知,以及皮带的智能控制.灵活架构.高效集成.快速开发! 本文分享自华为云社区<华夏天信携手华 ...
- 【有奖征文】WEB前端大作战,走在技术最前端!
摘要:投稿分享你在前端领域的积累,秀出你的技术"肌肉",为自己,也为技术发声. 近几年大家对于WEB前端的关注度很高, 比如整体势头发展良好,各种技术百花齐放,人才稀缺, 随着互联 ...
- Scrum Master们,难道每天都在摸鱼?
摘要:众所周知,Scrum Master是服务型领导--其本身不参与日常的研发工作,写代码.改Bug的工作都让团队干了,Scrum Master到底干了啥?Scrum Master工作的好坏应该如何衡 ...
- CANN 5.0黑科技解密 | 算力虚拟化,让AI算力“物尽其用”
摘要:算力虚拟化技术对消费者而言,可有效降低算力的使用成本,对于设备商或运营商而言,则可极大提升算力资源的利用率,降低设备运营成本. 为什么要做算力虚拟化 近年来,人工智能领域呈井喷式发展,算力就是生 ...
- 基于AIO架构smarthttp开发的完整MVC框架
基于AIO架构smarthttp开发的完整MVC框架 写了篇<基于jdk自带httpserver开发的最小完整MVC框架>,就再写篇AIO的MVC DEMO启动时间:0.1s(应该算少的吧 ...
- Appium介绍及第一个例子
Appium介绍 appium是开源的移动端自动化测试框架 appium可以测试原生的,混合的,以及移动端的项目 appium可以测试ios,android应用 appium是跨平台的,可以用在osx ...
- 用ChatGPT 玩转哔哩哔哩
用ChatGPT 玩转哔哩哔哩 哔哔终结者 BibiGPT 哔哩哔哩 BiliGPT,一款智能AI工具,帮助用户一键总结 哔哩哔哩视频内容,非常省心,软件基于GPT-3.5 AI,如果无法使用,可以使 ...
- java对excle操作:下载、上传以及上传中错误数据动态生成excle给用户下载
工作中经常遇到excle文件的上传下载,这里就总结一下相关的操作,尤其是最后一个方法"上传excle文件校验数据格式,挑出格式错误的数据"网上没有找到相关的例子,自己组合改写了一下 ...
- C# 防XSS攻击 示例
思路: 对程序代码进行过滤非法的关键字 新建控制台程序,编写代码测试过滤效果 class Program { static void Main(string[] args) { //GetStrReg ...