亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一文帶你了解什么是Vue?Vapor

 更新時(shí)間:2024年11月26日 14:42:18   作者:前端歐陽  
隨著Svelte和SolidJS的流行,無虛擬DOM模式逐漸開始火了起來,Vue?Vapor就是一個(gè)無虛擬DOM模式版本的vue,下面就跟隨小編一起來深入了解一下Vue?Vapor吧

前言

隨著SvelteSolidJS的流行,無虛擬DOM模式逐漸開始火了起來。vue也推出了無虛擬DOM模式的版本,就是我們今天要講的Vue Vapor。

什么是Vue Vapor

Vue Vapor是一個(gè)無虛擬DOM模式版本的vue。這個(gè)倉庫是2023年11月9日基于vuejs/core倉庫(也就是vue3倉庫)新建的,項(xiàng)目地址為 https://github.com/vuejs/core-vapor。Vue Vapor目前還處于實(shí)驗(yàn)階段,不過你可以通過官方提供的Vue Vapor演練場在線體驗(yàn)無虛擬DOM版本的vue。playground演練場的地址為:https://vapor-repl.netlify.app

目前Vue Vapor只實(shí)現(xiàn)了vue3中的部分功能,KeepAliveTeleport等還未實(shí)現(xiàn)。詳情查看官方的TODO:https://github.com/vuejs/core-vapor?tab=readme-ov-file#todo

如何使用Vue Vapor

對于使用者來說無虛擬DOM模式版本的vue和目前的vue3用法是一樣的,vue只是對內(nèi)部實(shí)現(xiàn)進(jìn)行了修改,對外暴露出的API還是一樣的,當(dāng)然關(guān)于虛擬DOM相關(guān)的API在Vue Vapor中沒有了。

我們來看看一個(gè)demo,和目前vue3寫法是一樣的:

<script setup>
import { ref } from 'vue'
const msg = ref('Hello World!')
</script>

<template>
  <h1>{{ msg }}</h1>
  <input v-model="msg" />
</template>

我們再來看看運(yùn)行效果:

從*.vue文件渲染到瀏覽器真實(shí)DOM的過程

我們先來看看目前版本的vue是如何從一個(gè)*.vue文件渲染到瀏覽器真實(shí)DOM?

目前的vue是通過webpack或者vite等工具先將*.vue文件編譯成一個(gè)js文件,js文件中主要的就是render函數(shù)。然后執(zhí)行render函數(shù)生成虛擬DOM,再調(diào)用瀏覽器的DOM API根據(jù)虛擬DOM生成真實(shí)DOM掛載到瀏覽器上。

我們再來看看Vue Vapor是如何從一個(gè)*.vue文件渲染到瀏覽器真實(shí)DOM?

也是一樣的首先通過webpack或者vite等工具先將*.vue文件編譯成一個(gè)js文件,js文件中主要的就是render函數(shù)。然后執(zhí)行render函數(shù)后會直接調(diào)用瀏覽器的DOM API生成真實(shí)DOM掛載到瀏覽器上。其實(shí)就是跳過了虛擬DOM的過程。

沒有虛擬DOM后,Vue Vapor如何實(shí)現(xiàn)響應(yīng)式

我們先來看看demo編譯后的js代碼中的render函數(shù),下面是我簡化后的代碼:

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標(biāo)簽dom元素。明顯可以看見render函數(shù)中沒有createElementVNode等生成虛擬DOM的函數(shù)調(diào)用。

我們先來看看_withDirectives函數(shù),vue3withDirectives函數(shù)的功能為給虛擬DOM增加自定義指令。我們這里沒有虛擬DOM,所以這里是給真實(shí)DOM(input輸入框)增加v-model的指令。

我們再來看看下面 _on函數(shù),這里是讓input輸入框監(jiān)聽一個(gè)名為update:modelValue的事件,觸發(fā)事件后會將上下文中的msg變量的值更新為輸入框中的輸入值。

我們最后來看看_renderEffect函數(shù),看名字你可能已經(jīng)猜出來了。這個(gè)函數(shù)和vue3中的watchEffect比較相似,會立即運(yùn)行一個(gè)函數(shù)。并且追蹤函數(shù)中用的的依賴,這里的依賴是msg變量。當(dāng)依賴的值變化時(shí)會再次執(zhí)行這個(gè)函數(shù)。

這里的_setText(n1, _ctx.msg),實(shí)際就是執(zhí)行了n1.textContent = _ctx.msg。textContent 屬性表示一個(gè)節(jié)點(diǎn)及其后代的文本內(nèi)容,也可能通過給它賦值的方式刪除它的所有子節(jié)點(diǎn),并替換為一個(gè)具有給定值的文本節(jié)點(diǎn),和innerText功能比較相似。

當(dāng)msg變量的值變了后就會執(zhí)行回調(diào)函數(shù),在回調(diào)函數(shù)中會執(zhí)行_setText函數(shù)。_setText函數(shù)會通過更新h1標(biāo)簽的textContent屬性讓h1標(biāo)簽始終顯示msg變量最新的值,從而實(shí)現(xiàn)響應(yīng)式。

總結(jié)

本文介紹了Vue Vapor,沒有虛擬DOM版本的vue。對于普通開發(fā)者來說Vue Vapor其實(shí)和目前的vue3沒有什么區(qū)別,前提是不涉及虛擬DOM。只是vue在內(nèi)部實(shí)現(xiàn)上去掉了虛擬DOM,改為直接操作真實(shí)DOM。

到此這篇關(guān)于一文帶你了解什么是Vue Vapor的文章就介紹到這了,更多相關(guān)Vue Vapor內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue移動端時(shí)彈出側(cè)邊抽屜菜單效果

    vue移動端時(shí)彈出側(cè)邊抽屜菜單效果

    這篇文章主要介紹了vue移動端時(shí)彈出側(cè)邊抽屜菜單,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • vue+element-ui:使用el-dialog時(shí)彈框不出現(xiàn)的解決

    vue+element-ui:使用el-dialog時(shí)彈框不出現(xiàn)的解決

    這篇文章主要介紹了vue+element-ui:使用el-dialog時(shí)彈框不出現(xiàn)的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue中如何點(diǎn)擊獲取當(dāng)前元素下標(biāo)

    Vue中如何點(diǎn)擊獲取當(dāng)前元素下標(biāo)

    這篇文章主要介紹了Vue中如何點(diǎn)擊獲取當(dāng)前元素下標(biāo)問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • vue3保存屬性自動換行問題及解決

    vue3保存屬性自動換行問題及解決

    這篇文章主要介紹了vue3保存屬性自動換行問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Element?ui中menu組件(el-menu/el-menu-item/el-submenu/template)層級結(jié)構(gòu)與用法示例

    Element?ui中menu組件(el-menu/el-menu-item/el-submenu/template)

    最近在使用Element開發(fā)時(shí)遇到了不少問題,下面這篇文章主要給大家介紹了關(guān)于Element?ui中menu組件(el-menu/el-menu-item/el-submenu/template)層級結(jié)構(gòu)與用法的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • Vue表情輸入組件 微信face表情組件

    Vue表情輸入組件 微信face表情組件

    這篇文章主要為大家詳細(xì)介紹了Vue表情輸入組件,微信face表情組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • Vue中使用js制作進(jìn)度條式數(shù)據(jù)對比動畫

    Vue中使用js制作進(jìn)度條式數(shù)據(jù)對比動畫

    這篇文章主要為大家詳細(xì)介紹了Vue中使用js制作進(jìn)度條式數(shù)據(jù)對比動畫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 使用Vue.js實(shí)現(xiàn)數(shù)據(jù)的雙向綁定

    使用Vue.js實(shí)現(xiàn)數(shù)據(jù)的雙向綁定

    在Vue.js中,雙向數(shù)據(jù)綁定是一項(xiàng)非常強(qiáng)大的功能,它能夠使數(shù)據(jù)和視圖之間保持同步,讓開發(fā)者更加方便地操作數(shù)據(jù),在本文中,我們將介紹如何用Vue.js實(shí)現(xiàn)數(shù)據(jù)的雙向綁定,需要的朋友可以參考下
    2023-04-04
  • element-ui中el-cascader動態(tài)加載和默認(rèn)值詳解

    element-ui中el-cascader動態(tài)加載和默認(rèn)值詳解

    vue+elementUI項(xiàng)目中el-cascader級聯(lián)選擇器使用頻率非常高,下面這篇文章主要給大家介紹了關(guān)于element-ui中el-cascader動態(tài)加載和默認(rèn)值的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • 詳解vee-validate的使用個(gè)人小結(jié)

    詳解vee-validate的使用個(gè)人小結(jié)

    本篇文章主要介紹了詳解vee-validate的使用個(gè)人小結(jié),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-06-06

最新評論