精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Vue無虛擬DOM模式即將到來

開發 前端
不過不管怎么說,我對這個實驗性特性還是非常期待的。因為這個編譯策略編譯成web components?很可能會是一個非常不錯的選擇,總之,期待無虛擬DOM的到來!

 流行趨勢 

不知大家發現沒有,自從2021年以來,無虛擬DOM框架/庫/編譯器獲得了極大的矚目,最為典型的兩個項目:

  • Svelte
  • Solid.js

我們來看看他倆究竟有多勇:

圖片

(來自https://www.tecla.io/blog/top-js-frameworks)

可以看到Svelte去年一年在GitHub上增長的Star接近Vue,甚至力壓老牌經典框架Angular!

再來看看這個:

圖片

滿意度甚至超越React和Vue,(吐槽:Angular這滿意度趨勢…)

圖片

感興趣程度同樣霸榜,只不過這回剛好反過來:Svelte力壓Solid,Vue力壓React(越來越多的人對Vue感興趣了哈)。Angular頹勢已顯,氣數已盡了?別擔心!下一個選項(Usage)讓Angular來告訴你,什么叫你大爺永遠是你大爺:

圖片

奇怪,感覺自己身邊明明沒那么多人用Angular,怎么肥四?這是因為調查對象主要以歐美地區為主(尤其美國):

圖片

母語為英語的人占多數:

圖片

年輕人為主:

圖片

這就很完美的解釋了為什么Solid和Svelte的受歡迎程度會那么高,年輕啊!折騰啊!你要是五六十歲了(在中國應該沒有這個歲數的程序員了吧)你也不愿意折騰那些亂七八糟的。

圖片

年輕不代表是新手,還是有相當一部分有經驗的開發者參與調查的。

數據來源:https://2021.stateofjs.com/en-US/libraries/front-end-frameworks/

不過這些數據還不能證明Svelte和Solid已經成為流行框架\庫\編譯器了,有相當一部分叫好不叫座的,我們來看看npm的數據:

哎呀!暴露了暴露了,再來看看Google搜索量:

可以看到三大框架依然是主流哈,而且Vue和Angular的差距已經越來越小了,當然還因為有股神秘的東方力量屏蔽掉了大部分去Google搜索Vue的,不然我相信Vue的數據一定可以超越Angular的。

數據源自https://trends.google.com/trends/explore?cat=31&date=today%205-y&q=React%20javascript,Vue%20javascript,Angular%20javascript,Solid.js%20javascript,Svelte%20javascript

沒想到對Svelte最感興趣的居然是韓國人!雖然三大框架YYDS,但作為后起之秀并且在沒有明顯優勢的情況下(綜合情況,光寫個Hello World確實誰也比不過Svelte)依然能夠從三大框架嘴里分一杯小小的羹,并且還能夠獲得如此巨大的關注度,那就證明無虛擬DOM的趨勢已經悄然興起了。

為什么這玩意會成為一種趨勢呢?有啥好處?好處就是性能!

什么?虛擬 DOM 不就是為了提升性能的嗎?!是也不是,推薦讀一下這篇:

[0]《網上都說操作真實 DOM 慢,但測試結果卻比 React 更快,為什么?》

他們會火不是沒有原因的,我們來看看他倆的性能:

可以用傲視群雄這四個字來形容了,Vue之前一直以高性能為傲,但被人超了怎么可能會甘心?畢竟Vue和React不一樣,當數據更新時Vue是知道該更新哪個組件的,React不知道所以它只能用diff算法,沒有虛擬DOM根本不行。那Vue干嘛也要來一個虛擬DOM呢?尤雨溪也是這么想的!

其實他早就有過放棄虛擬DOM的想法了:在尤雨溪發表的《Vue3的設計過程》(翻譯版)一文中,尤大說:一種選擇是放棄虛擬 DOM 并直接生成命令式 DOM 操作,但這將消除直接編寫虛擬 DOM 渲染功能的能力,我們發現這對高級用戶和庫作者非常有價值。

那時候Vue3還沒發布呢,Vue3的createRenderer就是利用虛擬DOM來實現跨平臺的,但成天老是跨平臺跨平臺的,我們平時開發業務又有多少跨平臺項目呢?

現在追求的就是一個輕量級,沒有了虛擬DOM就沒有了Diff算法,不僅可以不用運行一些無謂的計算,而且打包出來的體積那可真是輕上加輕啊!它不香嗎?

但也不能完全放棄虛擬DOM啊,一方面虛擬DOM還是有它大展宏圖的場景的。另一方面你直接把虛擬DOM刪了,那些庫怎么辦?它們有多少是依賴虛擬DOM的API的呢?有多少組件庫用的是jsx呢:

[1]《為什么 Vue3 的組件庫都在使用 jsx/tsx?》

去掉了虛擬DOM的話,那些組件庫是不是就用不了了呢?那咱們可以搞個模式出來嘛!

無虛擬DOM模式

首先咱們先把尤大在發布會上說的話(重點部分)翻譯下,為了節省篇幅不重點的地方就不貼上來了:

主要的事情就是:我們想要探索一種新的編譯策略

我們都知道Vue是一個基于模板的框架,即使你能用jsx能用虛擬DOM,但大多數用戶還是會用template模板。

(挨個截圖太麻煩了我就不截了,還浪費篇幅,我就直接寫翻譯了,感興趣的話可以點進去視頻鏈接[2]看)

由于Vue的大部分用戶都用單文件組件來寫代碼,所以我們其實是有機會把組件編譯成原生JS、CSS的。所以編譯的這個步驟是有機會能讓Vue變成一個超級編譯器的!這將會很有趣,所以我們想要探索一下新的編譯策略,這也是受到了Solid.js的啟發。新的編譯策略可以把template模板編譯成命令式的DOM操作+響應式的setup綁定以代替虛擬DOM和render函數。所以想象一下,當我們寫了一個這樣的組件:

(此處省略一些廢話:這是script setup語法、看這里有個button按鈕、我們給按鈕綁定一個響應式的值之類的話)

圖片

我們生成的將會是這樣的代碼,生成出來的代碼量非常少,目前的想法是我們過一遍虛擬DOM樹然后生成真實DOM的操作。我們會在編譯期分析template模板里的HTML的結構并將其字符串化:

圖片

為了能讓打包出來的內容最小化,去掉了結束標簽以及各種綁定的屬性。然后再生成一個cloneNode:

圖片

通過分析得出哪些屬性是響應式的,把它們都放在effect里,再綁定事件,全部都是非常好理解的DOM操作:

圖片

(這不比Svelte生成出來的那一大坨好多了?)

兩種模式

這里的兩種模式指的并不是虛擬DOM模式和無虛擬DOM模式這兩種模式,而是無虛擬DOM模式下還可以繼續再往下細分出來兩種模式:

圖片

組件模式

比方說你現在手里已經有了長期維護的Vue3項目,你要是直接換成無虛擬DOM模式那肯定是要出問題的,所以可以采用組件模式來精確控制哪些組件不需要虛擬DOM。

比方說你的項目中采用了尤大推薦的naive-ui這個組件庫,我們打開一個比較常用的組件Button來看一下:

圖片

tsx結尾,那虛擬DOM算是沒跑了。不過tsx也照樣可以給改成生成真實DOM的函數啊,solid.js不就是這么干的嗎?其實理論上來說確實是可以做到的,我們點進去再看一眼:

圖片

這里用到了h函數,這個函數是專門用來生成虛擬DOM的,假如你把項目全部換成了無虛擬DOM模式同時這些庫還沒來得及跟進的話,那肯定是不行的。

所以你可以控制,你哪個組件里沒用這個組件庫,你再給這個組件單獨的一個編譯策略(無虛擬DOM模式)。

既然有組件級的那就肯定有應用級的,比方說你想開發一個UI高度定制化的H5活動頁。

一般來說這樣的頁面不會用組件庫,都是自己寫樣式。另一方面這種活動頁當然是越小越好,越快越好啦!那么此時你就可以采用全局無虛擬DOM模式。

怎么感覺這是在搶Svelte飯碗呢?我看技術論壇已經有人分享了自己用Svelte來開發一些小頁面的文章了,這回再有什么性能跑分之類的評測Vue應該不會再輸給Svelte了(看情況,組件越少Svelte越占優,反之則Vue占優)

機遇與挑戰

最近前端可謂是越來越卷了,你要是去面試稍微高級點的崗位的話,估計很可能會問你Vue怎么編譯的兩種模式了(即使你并不感興趣)。

但我發現很多人對自己做一款組件庫非常感興趣,從文章列表里看一下究竟有多少組件庫相關的文章就能夠一探究竟了。而且很多教大家搭建組件庫的文章也是點贊量非常高,還有很多文章推薦自己做出來的組件庫。

只可惜大部分個人做的組件庫都是孤芳自賞,沒幾個人用。一方面的個人開發者可能隨時刪庫跑路,不穩定。誰知道你寫的那玩意有多少bug呢?另一方面大家也更愿意用Star非常多的組件庫,證明其穩定。

所以大家如果想從主流組件庫那里分一杯羹的話還是非常困難的。那現在這個無虛擬DOM模式是不是就是一個千載難逢的大好時機?不過我個人依然感覺希望不大,因為那些主流組件庫肯定會立馬跟進,搞一款無虛擬DOM適配版。

不過不管怎么說,我對這個實驗性特性還是非常期待的。因為這個編譯策略編譯成web components很可能會是一個非常不錯的選擇,總之,期待無虛擬DOM的到來!

文章鏈接:

[0]: https://www.zhihu.com/question/31809713/answer/53544875

[1]: https://www.zhihu.com/question/436260027/answer/1647182157

[2]: https://www.bilibili.com/video/BV12S4y1e7pn?p=1&share_medium=android&share_plat=android&share_session_id=4e2c7597-7fa7-4e0a-a098-5e0aa675b035&share_source=WEIXIN&share_tag=s_i&timestamp=1655041421&unique_k=nLvKgzv&vd_source=3490d817b36fc42ec9a252b6cd0d6baf

責任編輯:武曉燕 來源: 前端學不動
相關推薦

2021-12-14 10:04:52

無密碼時代多因素身份驗證MFA

2018-08-15 09:12:58

2023-11-10 09:04:47

2022-10-12 00:07:25

加密貨幣區塊鏈比特幣

2015-07-03 09:45:34

火車WiFi

2024-09-02 08:31:46

2015-06-16 10:50:45

2022-09-11 08:10:44

Fedora

2010-10-25 13:12:13

云計算

2015-04-29 09:55:50

Windows 10

2013-01-25 09:43:14

2013-10-09 10:50:00

智能電視智能電視庫應用

2021-01-12 07:10:05

VR虛擬現實

2015-02-09 15:37:46

2013-03-11 09:43:30

VMware vClo公有云服務

2010-04-19 15:58:33

互聯網

2009-05-05 10:36:44

KDESocialDesktop

2009-04-14 22:31:35

Linux開源

2020-04-08 10:19:40

云計算云計算2.0

2022-10-17 10:02:29

5G物聯網
點贊
收藏

51CTO技術棧公眾號

欧美成在线视频| 欧美日韩一区二区在线| 91美女高潮出水| 久久久久黄色片| 欧美美女啪啪| 欧美日韩成人综合| 久久久久久久9| 电影在线一区| 粉嫩高潮美女一区二区三区| 国产91精品不卡视频| 青青青视频在线播放| 91精品短视频| 欧美精品乱码久久久久久| 久久久亚洲国产精品| av电影在线播放高清免费观看| 国产精品77777| 国产精品久久久久久网站| 精品少妇theporn| 日韩一区欧美| 日韩精品一区二区三区第95| 欧美黄色一级片视频| 国产三级在线观看| 成人精品一区二区三区四区| 国产在线播放不卡| 天天干天天色综合| 影音先锋一区| 免费不卡在线观看av| 国产传媒国产传媒| 国模冰冰炮一区二区| 国产精品自拍av| 国产成人综合亚洲| 不卡的免费av| 91精品亚洲| 另类美女黄大片| 久久99亚洲热视| 国产日本欧美在线观看| 欧美又粗又大又长| 欧美日韩高清| 亚洲美女喷白浆| 国内精品免费视频| 国产亚洲高清在线观看| 欧美在线一区二区三区| 国产淫片免费看| 黄污视频在线观看| 亚洲天堂av老司机| 一本久久a久久精品vr综合| 欧美精品久久久久久久久久丰满| 成人一区二区三区视频在线观看 | 成人性生交大片免费观看嘿嘿视频| www.伊人久久| 奶水喷射视频一区| 日本伊人精品一区二区三区介绍 | 国产日韩高清一区二区三区在线| 欧美美最猛性xxxxxx| 中国毛片直接看| 亚洲最大av| 欧美乱妇高清无乱码| 天天综合天天做| 在线精品国产| 欧美黑人性猛交| 国产精品99精品| 亚洲黄色在线| 欧美一区在线直播| 日韩精品一区二区不卡| 亚洲女同同性videoxma| 欧洲成人午夜免费大片| 人人爽人人爽人人片av| 日韩国产精品大片| 国产精品夜间视频香蕉| 国产一区二区三区视频免费观看| 奇米精品一区二区三区在线观看一| 国产精品国语对白| 一区二区三区免费在线视频| 国内精品免费**视频| 91在线观看免费高清| 亚洲国产精品视频在线| 不卡av在线网| 日本在线观看一区| 色网站在线看| 亚洲一区免费观看| 成人一级片网站| 少妇高潮一区二区三区99| 日韩美一区二区三区| 久久人人爽人人爽人人片| 成人在线一区| 欧美寡妇偷汉性猛交| 伊人手机在线视频| 久久精品国产久精国产爱| 96成人在线视频| 日韩a在线观看| 中文字幕永久在线不卡| 无码人妻少妇伦在线电影| 日韩免费va| 日韩一区二区三区电影| 人妻无码一区二区三区| 国产精品久久久久久| 久久久久久网址| 免费黄色一级大片| 国产宾馆实践打屁股91| 欧美精品亚洲| 丝袜国产在线| 日本道在线观看一区二区| 精品亚洲视频在线| 色狼人综合干| 麻豆乱码国产一区二区三区| 国产美女激情视频| 国产成人三级在线观看| 日韩欧美一区二区视频在线播放 | 亚洲精品欧美二区三区中文字幕| 黄色一级片国产| 九色成人搞黄网站| 欧美mv和日韩mv的网站| 人妻互换一区二区激情偷拍| 亚洲人成毛片在线播放女女| 91精品久久久久久久久青青 | 中文字幕日韩国产| 91在线码无精品| 人妻激情另类乱人伦人妻| 全球最大av网站久久| 亚洲精品大尺度| 青青草原在线免费观看| 美女国产一区二区三区| 麻豆91蜜桃| 91九色在线看| 日韩亚洲欧美在线观看| 国产三级在线观看完整版| 国产欧美丝祙| 国产免费一区二区三区| 日本在线视频www鲁啊鲁| 欧美日韩免费高清一区色橹橹| 国产草草浮力影院| 国产一区久久| 超碰97在线播放| 亚洲精品一线| 91精品国产欧美一区二区| 色www亚洲国产阿娇yao| 免费人成精品欧美精品| 欧美日韩在线精品| 日韩电影大全网站| 亚洲欧美日韩天堂一区二区| 国产成人在线播放视频| 成人免费视频一区| 日本黄大片在线观看| 日韩精品亚洲专区在线观看| 久久这里只有精品99| 国产露脸91国语对白| 国产精品国产成人国产三级 | 成熟亚洲日本毛茸茸凸凹| 亚洲欧美日韩不卡一区二区三区| 亚洲成a人片| 亚洲欧洲在线视频| 青青国产在线视频| 欧美激情一二三区| www.日日操| 波多野结衣在线观看一区二区三区| 日韩免费在线看| 国产黄在线看| 欧美日韩成人综合| 中文字幕影音先锋| 99精品视频一区| 欧美一级黄色片视频| 国内黄色精品| 成人黄色在线免费| 日本在线观看高清完整版| 亚洲成人av在线播放| 波多野结衣视频网站| 91亚洲国产成人精品一区二三| 日韩精品 欧美| 久久av影视| 国产欧美精品一区二区| 色屁屁www国产馆在线观看| 亚洲成人av片| 五月婷婷激情视频| 成人欧美一区二区三区在线播放| 搡的我好爽在线观看免费视频| 国产精品vip| 久久综合入口| 欧洲亚洲精品| 久久久亚洲国产| 久久久久久久影视| 欧美午夜不卡在线观看免费| 久久精品视频免费在线观看| av中文字幕不卡| 91制片厂毛片| 伊人精品在线| 四虎影院一区二区三区| 精品一区二区三区四区五区| 97在线视频免费播放| 国产高清在线观看| 精品国产凹凸成av人导航| 日韩无码精品一区二区三区| 中文在线免费一区三区高中清不卡| 波多野结衣网页| 亚洲综合三区| 肉大捧一出免费观看网站在线播放| 牛牛影视久久网| 国产精品福利网| sqte在线播放| 啊v视频在线一区二区三区| 亚洲国产视频一区二区三区| 91久久国产最好的精华液| 唐朝av高清盛宴| 中文字幕精品三区| 国产xxxxxxxxx| 韩国一区二区视频| 熟妇人妻va精品中文字幕| 欧美亚韩一区| 在线看视频不卡| 欧美女优在线视频| 国产精品久久久一区二区三区| 99亚洲伊人久久精品影院| 韩国欧美亚洲国产| free性欧美hd另类精品| 亚洲色图第一页| 日本美女一级片| 欧美一区二区精美| 一级特黄特色的免费大片视频| 欧美色视频日本版| 国产在线观看你懂的| 国产精品传媒入口麻豆| 一区二区黄色片| 99re这里都是精品| 亚洲视频天天射| 国产剧情一区二区| 污视频网址在线观看| 日韩精品三区四区| 黄色片久久久久| 日韩午夜激情| www.avtt| 激情久久一区| 高清无码一区二区在线观看吞精| 国产精品久久久久久久久久10秀| 欧美日韩综合久久| 羞羞色国产精品网站| 国产在线一区二区三区欧美 | 欧美在线3区| 亚洲+变态+欧美+另类+精品| 国产精品一区在线观看| 色播一区二区| yellow视频在线观看一区二区| 电影一区二区三区久久免费观看| 91精品国产自产在线观看永久| 日韩精品免费观看视频| 国产精品高潮粉嫩av| 日韩和的一区二在线| 国产福利成人在线| 第四色男人最爱上成人网| 国产成人一区二区三区小说| 欧美18—19sex性hd| 国产成人一区三区| 国产精品4hu.www| 91社区国产高清| 激情视频亚洲| 成人av网站观看| 久久夜色电影| 欧美日韩一区综合| 色呦哟—国产精品| 国产精品jizz在线观看老狼| 亚洲天堂一区二区三区四区| www.激情网| 99精品热6080yy久久| 欧美日韩二三区| 久久久久综合| 亚洲美女性囗交| 国产成人综合精品三级| 中文字幕乱码一区| 国产香蕉久久精品综合网| 国产精品久久久久久久av| 中文字幕中文字幕一区二区| 农村妇女精品一区二区| 午夜精品久久久久久久| 老熟妇仑乱一区二区av| 欧美日韩一区成人| 亚洲精华国产精华精华液网站| 亚洲第一页中文字幕| 黄色毛片在线观看| 久久av中文字幕| 高端美女服务在线视频播放| 国产精品第一第二| 亚洲精品黑牛一区二区三区| 久久久99爱| 日韩一区二区在线免费| 人妻少妇精品无码专区二区| 久久午夜av| 中文字幕日本人妻久久久免费 | 一级 黄 色 片一| 国产成人免费视频| 好吊日免费视频| 亚洲丝袜精品丝袜在线| 欧美日韩精品区| 欧美精品1区2区3区| 日本xxxxwww| 色妞久久福利网| 色资源二区在线视频| 91精品国产自产在线老师啪| 日韩欧美影院| 中文字幕第一页亚洲| 翔田千里一区二区| 色哟哟网站在线观看| 国产欧美日韩视频在线观看| 精品人妻在线播放| 欧美日本一区二区三区四区| 天天综合天天色| 欧美不卡视频一区发布| 日韩电影大全网站| 国产一区免费在线| 999久久久国产精品| 丁香花在线高清完整版视频| 91国偷自产一区二区使用方法| 国产毛片在线视频| 亚洲欧洲自拍偷拍| 波多野结衣久久| 成人av在线亚洲| 在线亚洲a色| 欧美视频在线观看网站| 国产一区二区三区四| 第一次破处视频| 婷婷成人激情在线网| www.天堂av.com| 久久国内精品一国内精品| 奇米777日韩| 久久无码av三级| 制服诱惑一区| 日本一不卡视频| 中文字幕5566| 天天色天天爱天天射综合| 国产xxxx孕妇| 伦理中文字幕亚洲| 香蕉久久久久久| 午夜精品一区二区三区在线观看 | 久草视频这里只有精品| 韩日精品视频一区| 久久成人小视频| 欧美日韩视频在线第一区| 国产三级在线观看| 日本高清+成人网在线观看| 美女视频亚洲色图| 欧美午夜小视频| 99精品国产视频| 日韩成人免费在线视频| 精品第一国产综合精品aⅴ| 先锋影音在线资源站91| 97人人模人人爽人人少妇| 最新欧美人z0oozo0| √天堂资源在线| 亚洲欧美激情插| 亚洲AV无码国产精品午夜字幕| 免费91在线视频| 99a精品视频在线观看| 中文字幕日韩精品无码内射| 东方aⅴ免费观看久久av| 精品无码免费视频| 亚洲精品第一页| 男人最爱成人网| 亚洲一区不卡在线| 国产一区二区按摩在线观看| 免费一级黄色大片| 亚洲精品理论电影| 亚洲伦乱视频| 尤物国产精品| 国产iv一区二区三区| 91精品国产乱码久久久张津瑜| 亚洲美女黄色片| 国产91在线播放精品| 热这里只有精品| 成人国产一区二区三区精品| 国产成人精品网| 日韩综合视频在线观看| 国产精品成人3p一区二区三区| avav在线播放| 91免费观看国产| 91福利在线观看视频| 欧美激情精品久久久久久| 日韩av资源网| 亚洲无吗一区二区三区| 亚洲日本成人在线观看| 熟妇人妻一区二区三区四区| 国产成人精品一区| 欧美伊人影院| 日韩一区二区免费高清| 草美女在线观看| 欧美精品一区二区视频 | 黄色成人av网| 水莓100国产免费av在线播放| 国产精品高潮呻吟久久av野狼| 天天av综合| 91av在线免费| 7777精品伊人久久久大香线蕉的 | 国产精品s色| 欧美日韩高清丝袜| 欧美成人一区二区三区在线观看| 欧美aa在线| 国产精品12p| 久久免费电影网| 国产激情视频在线播放| 日韩av大片免费看| 好吊日精品视频| 九九九视频在线观看| 亚洲第一区中文99精品| 青青草国产一区二区三区|