国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

攜程機票前端Svelte生產實踐

開發 前端
整體來說,Svelte 繼前端三大框架之后推陳出新,以一種新的思路實現了響應式。因其起步時間不算很長,國內使用程度仍然偏少,目前來說其生態還不夠完備。

?作者 | shuan feng,攜程高級前端開發工程師,關注性能優化、低代碼、svelte等領域。

一、技術調研

最近幾年,前端框架層出不窮。近兩年,前端圈又出了一個新寵:Svelte?。作者是 Rich Harris?,也就是 Ractive?, Rollup? 和 Buble的作者,前端界的“輪子哥”。

通過靜態編譯減少框架運行時的代碼量。一個 Svelte 組件編譯之后,所有需要的運行時代碼都包含在里面了,除了引入這個組件本身,你不需要再額外引入一個所謂的框架運行時!

在Github上擁有 5w 多的 star!

在最新的State of JS 2021和Stack Overflow Survey 2021的排名情況中,也一定程度上反映了它的火熱程度。

在早前知乎的如何看待 svelte 這個前端框架?問題下面,Vue的作者尤雨溪也對其做出了極高的評價:

去它的官網看一下:

官網上清楚的表明了三大特性:

  • Write less code
  • No virtual DOM
  • Truly reactive

1.1 Write less code

顧名思義,是指實現相同的功能,Svelte的代碼最少。這一點會在后面的示例中有所體現。

1.2 No virtual DOM

Svelte?的實現沒有利用虛擬DOM?,要知道Vue和React?的實現都是利用了虛擬DOM?的,而且虛擬DOM不是一直都很高效的嗎?

Virtual DOM 不是一直都很高效的嗎?

其實 Virtual DOM?高效是一個誤解。說 Virtual DOM? 高效的一個理由就是它不會直接操作原生的 DOM? 節點,因為這個很消耗性能。當組件狀態變化時,它會通過某些 diff? 算法去計算出本次數據更新真實的視圖變化,然后只改變需要改變?的 DOM 節點。

用過 React? 的同學可能都會體會到 React? 并沒有想象中那么高效,框架有時候會做很多無用功,這體現在很多組件會被“無緣無故”進行重渲染(re-render?)。所謂的 re-render? 是你定義的 class Component? 的 render 方法被重新執行,或者你的組件函數被重新執行。

組件被重渲染是因為 Vitual DOM? 的高效是建立在 diff? 算法上的,而要有 diff? 一定要將組件重渲染才能知道組件的新狀態和舊狀態有沒有發生改變,從而才能計算出哪些 DOM 需要被更新。

正是因為框架本身很難避免無用的渲染,React? 才允許你使用一些諸如 shouldComponentUpdate,PureComponent? 和 useMemo? 的 API 去告訴框架哪些組件不需要被重渲染,可是這也就引入了很多模板代碼。

那么如何解決 Vitual DOM? 算法低效的問題呢?最有效的解決方案就是不用 Virtual DOM!

1.3 Truly reactive

第三點真正的響應式?,上面也提到了前端框架要解決的首要問題就是:當數據發生改變的時候相應的 DOM? 節點會被更新,這個就是reactive。

我們先來看下Vue和React分別是如何實現響應式的。

React reactive

通過useState?定義countdown?變量,在useEffect?中通過setInterval使其每秒減一,然后在視圖同步更新。這背后實現的原理是什么呢?

React? 開發者使用 JSX? 語法來編寫代碼,JSX? 會被編譯成 ReactElement?,運行時生成抽象的 Virtual DOM。

然后在每次重新 render? 時,React? 會重新對比前后兩次 Virtual DOM?,如果不需要更新則不作任何處理;如果只是 HTML? 屬性變更,那反映到 DOM? 節點上就是調用該節點的 setAttribute? 方法;如果是 DOM? 類型變更、key? 變了或者是在新的 Virtual DOM? 中找不到,則會執行相應的刪除/新增 DOM 操作。

Vue reactive

用Vue?實現同樣的功能。Vue背后又是如何實現響應式的呢?

大致過程是編譯過程中收集依賴,基于 Proxy?(3.x) ,defineProperty?(2.x) 的 getter,setter? 實現在數據變更時通知 Watcher。

像Vue和React這種實現響應式的方式會帶來什么問題呢?

  1. diff 機制為 runtime 帶來負擔
  2. 開發者需自行優化性能
  • useMemo
  • useCallback
  • React.memo
  •  ...

那么Svelte又是如何實現響應式的呢?

Svelte reactive

其實作為一個框架要解決的問題是當數據發生改變的時候相應的 DOM? 節點會被更新(reactive?),Virtual DOM? 需要比較新老組件的狀態才能達到這個目的,而更加高效的辦法其實是數據變化的時候直接更新對應的 DOM 節點。

這就是Svelte?采用的辦法。Svelte?會在代碼編譯的時候將每一個狀態的改變轉換為對應DOM?節點的操作,從而在組件狀態變化的時候快速高效地對DOM節點進行更新。

深入了解后,發現它是采用了 Compiler-as-framework? 的理念,將框架的概念放在編譯時而不是運行時。你編寫的應用代碼在用諸如 Webpack? 或 Rollup? 等工具打包的時候會被直接轉換為 JavaScript? 對 DOM? 節點的原生操作,從而讓 bundle.js? 不包含框架的 runtime。

那么 Svelte? 到底可以將 bundle size? 減少多少呢?以下是 RealWorld? 這個項目的統計:

由上面的圖表可以看出實現相同功能的應用,Svelte的bundle size?大小是Vue的1/4?,是React的1/20?!單純從這個數據來看,Svelte?這個框架對bundle size的優化真的很大。

看到這么強有力的數據支撐,不得不說真的很動心了!

二、項目落地

為了驗證Svelte?在營銷 h5 落地的可能,我們選擇了口罩機項目:

上圖是口罩機項目的設計稿,不難看出,核心邏輯不是很復雜,這也是我們選用它作為Svelte嘗試的原因。

首先項目的基礎結構是基于svelte-webpack-starter創建的,集成了TypeScript、SCSS、Babel?以及Webpack5?。但這個基礎模板都只進行了簡單的支持,像項目中用到的一些圖片、字體等需要單獨使用loader去處理。

啟動項目,熟悉的hello world:

這里看下核心的

當然開發環境使用?webpack?有時不得不說體驗不太好,每次都要好幾秒,我們就用Vite?來替代了,基本都是秒開:圖片

Vite的配置也比較簡單:

2.1 組件結構差異

和 React? 組件不同的是,Svelte? 的代碼更像是以前我們在寫 HTML、CSS? 和 JavaScript?時一樣(這點和Vue很像)。

所有的 JavaScript? 代碼都位于 Svelte? 文件頂部的 <script></script>? 標簽當中。然后是 HTML? 代碼,你還可以在 <style></style>? 標簽中編寫樣式代碼。組件中的樣式代碼只對當前組件有效。這意味著在組件中為 <div>? 標簽編寫的樣式不會影響到其他組件中的 <div> 元素。

2.2 生命周期

Svelte? 組件的生命周期有不少,主要用到的還是 onMount?、 onDestoy、beforeUpdate、afterUpdate,onMount? 的設計和 useEffect? 的設計差不多,如果返回一個函數,返回的函數將會在組件銷毀后執行,和 onDestoy 一樣:

2.3 初始狀態

接下來是對初始狀態的定義:

我們發現代碼在對變量更新的時候并沒有使用類似React的setState?方法, 而是直接對變量進行了賦值操作。僅僅是對變量進行了賦值就可以引發視圖的變化, 很顯然是數據響應的, 這也正是Svelte的truly reactive的體現。

2.4 條件判斷

項目中使用了很多的條件判斷,React?由于使用了JSX?,所以可以直接使用JS?中的條件控制語句,而模板是需要單獨設計條件控制語法的。比如Vue?中使用了v-if。

Svelte?中則是采用了{#if conditions}、{:else if}、{/if}?,屬于Svelte?對于HTML的增強。

上面代碼中有這么一行:

$: buttonText = isTextShown ? 'Show less' : 'Show more'

buttonText?依賴了變量isTextShown?,依賴項變更時觸發運算,類似Vue?中的computed?,這里的Svelte?使用了$:?關鍵字來聲明computed變量。

這又是什么黑科技呢?這里使用的是 Statements and declarations? 語法,冒號:前可以是任意合法變量字符。

2.5 數據雙向綁定

項目中有很多地方需要實現雙向綁定?。我們知道React?是單向數據流,所以要手動去觸發變量更新。而Svelte和Vue都是雙向數據流。

Svelte?通過bind?關鍵字來完成類似v-model的雙向綁定。

2.6 列表循環

項目中同樣使用了很多列表循環渲染。Svelte?使用 {#each items as item}{/each}? 來實現列表循環渲染,這里的item?可以通過解構賦值,拿到item里面的值。

不得不說有點像ejs

2.7 父子屬性傳遞

父子屬性傳遞時,不同于React?中的props,Svelte? 使用 export? 關鍵字將變量聲明標記為屬性,export? 并不是傳統 ES6 的那個導出,而是一種語法糖寫法。

注意只有 export let 才是聲明屬性

2.8 跨組件通訊(狀態管理)

既然提到了父子組件通訊,那就不得不提跨組件通訊?,或者是狀態管理?。這也一直是前端框架中比較關注的部分,Svelte? 框架中自己實現了 store?,無需安裝單獨的狀態管理庫。你可以定義一個 writable store, 然后在不同的組件之間進行讀取和更新:

每個 writable store? 其實是一個 object?, 在需要用到這個值的組件里可以 subscribe? 他的變化,然后更新到自己組件里的狀態。在另一個組件里可以調用 set和update 更新這個狀態的值。

2.9 路由

Svelte 目前沒有提供官方路由組件,不過可以在社區中找到:

  • svelte-routing
  • svelte-spa-router

svelte-routing和react-router-dom 的使用方式很像:

而svelte-spa-router?更像vue-router一點:

2.10 UI

項目中也用到了組件庫,通常react?項目一般都會采用NFES UI?,但畢竟是react component?,在Svelte?中并不適用。我們嘗試在社區中尋找合適的Svelte UI?庫,查看了Svelte Material UI、Carbon Components Svelte等,但都不能完全滿足我們的需求,只能自己去重寫了(只用到了幾個組件,重寫成本不算很大)。

2.11 單元測試

單元測試用的是@testing-library/svelte:

基本用法和React是很類似的。

業務代碼遷移完畢,接著就是對原有功能case的逐一驗證。

為了驗證單單使用Svelte?進行開發的效果,我們沒有進行其他的優化,發布了一版只包含Svelte?的代碼到產線,來看下bundle size?(未做gzip?前)和lighthouse?評分情況:

除此之外,我們遵循lighthouse?給出的改進建議,對Performance、Accessibility和SEO做了更進一步的優化改進:

Performance?的提升主要得益于圖片格式支持webp?以及一些資源的延遲加載,Accessibility和SEO?的提升主要是對meta標簽的調整。

三、實踐總結

通過這次技改,我們對Svelte有了一些全新的認知。

整體來說,Svelte 繼前端三大框架之后推陳出新,以一種新的思路實現了響應式。

因其起步時間不算很長,國內使用程度仍然偏少,目前來說其生態還不夠完備。

但這不能掩蓋其優勢:足夠“輕”。Svelte?非常適合用來做活動頁,因為活動頁一般沒有很復雜的交互,以渲染和事件綁定為主。正如文章最開始說的,一個簡單的活動頁卻要用React?那么重?的框架多少有點委屈自己。所以對于一些營銷團隊,想在bundle size?上有較大的突破的話,Svelte是絕對可以作為你的備選方案的。

另外現在社區對于Svelte?還有一個很好的用法是使用它去做Web Component,好處也很明顯:

  • 使用框架開發,更容易維護
  • 無框架依賴,可實現跨框架使用
  • 體積小

所以對于想實現跨框架組件復用的團隊,用Svelte?去做Web Component也是一個很好的選擇。

責任編輯:未麗燕 來源: 攜程技術
相關推薦

2022-05-13 09:27:55

Widget機票業務App

2020-12-04 14:32:33

AndroidJetpackKotlin

2023-05-12 10:14:38

APP開發

2023-08-25 09:51:21

前端開發

2025-06-24 09:51:47

2017-04-11 15:11:52

ABtestABT變量法

2022-06-10 08:35:06

項目數據庫攜程機票

2023-11-13 11:27:58

攜程可視化

2024-09-10 16:09:58

2025-06-24 09:44:41

2022-08-06 08:27:41

Trace系統機票前臺微服務架構

2022-06-27 09:36:29

攜程度假GraphQL多端開發

2017-01-10 16:04:02

容器MySQL實踐

2017-04-11 15:34:41

機票前臺埋點

2025-07-11 09:09:00

2022-07-15 12:58:02

鴻蒙攜程華為

2023-09-05 07:40:37

PythonSDKAPI

2021-03-12 07:47:44

KubernetesRedis-clustRedis

2023-07-12 16:07:50

鏈路數據湖技術

2017-03-15 17:38:19

互聯網
點贊
收藏

51CTO技術棧公眾號

婷婷久久综合九色综合绿巨人| 精品视频在线一区二区在线| 动漫3d精品一区二区三区乱码| 欧美日韩一区二区三区四区五区| 欧美日韩国产中文| 亚洲日本理论电影| 欧美偷窥清纯综合图区| 久久久亚洲国产| 欧美风情在线视频| 国产一区二区动漫| 超碰一区二区| 欧美成人手机在线| 色综合视频一区二区三区44| 色老汉一区二区三区| 亚洲综合在线网站| 欧美视频免费| 久久午夜a级毛片| 国产免费av高清在线| 国产91精品在线观看| 久久久一本精品99久久精品66| 午夜视频在线观看精品中文 | 国产日韩精品一区二区浪潮av| 国内精品久久影院| xx免费视频| 成人亚洲精品久久久久软件| 性欧美长视频免费观看不卡| xxx在线免费观看| 欧美美女直播网站| 最新黄网在线观看| 欧美一二三四在线| 精品久久久久久综合日本 | 六月婷婷一区| 亚洲av综合色区| 亚洲男帅同性gay1069| 男人天堂久久久| 欧美日韩成人精品| 欧美在线日韩| www..com日韩| 欧美性xxxx极品高清hd直播| 91破解版在线看| 亚洲欧洲日韩一区二区三区| mm1313亚洲国产精品无码试看| 一本一本久久| 国产日韩一区二区三区| 亚洲欧美在线专区| 岛国一区二区三区高清视频| 欧美日韩导航| 久久综合伊人77777| 中文在线字幕免费观看| 在线观看亚洲精品视频| 激情婷婷丁香| 亚洲在线成人精品| 99视频在线视频| 国产精品无圣光一区二区| av片在线免费观看| 精品丝袜一区二区三区| 99热在线免费观看| 在线免费黄色| 国产日韩欧美日韩| 久久久国产午夜精品| av资源在线| 中文字幕中文字幕99| 在线观看国产精品网站| 四虎成人av| 日本a一级在线免费播放| 国产精品女人毛片| 先锋影音欧美性受| 亚洲乱码一区av黑人高潮 | 亚洲日本无吗高清不卡| 国产三级欧美三级日产三级99| 草b视频在线观看| 亚洲国产色一区| 国内老司机av在线| 久久亚洲精品国产亚洲老地址| sis001欧美| 色综合老司机第九色激情| 国产精品调教视频| 91地址最新发布| 国产精品一区免费在线观看| av日韩在线看| 亚洲一区二区精品久久av| 成人日韩精品| 热re99久久精品国99热蜜月| 激情av一区二区| av影片在线一区| 亚洲欧美电影院| 国产麻豆精品久久| 免费观看黄色网| 精品乱码一区二区三区| 亚洲国产精品久久久久秋霞不卡| 国产成人8x视频一区二区 | 久久www免费人成看片高清| 日韩激情电影| 欧美 日韩 国产 在线观看| 午夜精品一区二区三区三上悠亚| 日本一区二区三区视频在线| 国产成人精品免费视频大全最热 | av手机免费在线观看| 久久免费视频观看| 亚洲国产日本| 爱爱免费视频网站| 91国产高清在线| 99免费精品在线| 欧美精品高清| www一区二区www免费| 久久频这里精品99香蕉| 欧美综合在线视频| 久久激情五月激情| 男人j进女人j| 亚洲国产欧美一区二区三区同亚洲| 国产成人亚洲精品狼色在线| 91精品秘密在线观看| 欧美影院精品| 精品日韩av| www在线播放| 欧美18一12sex性处hd| 成年人午夜视频在线观看| 国产啪精品视频| 情事1991在线| 亚洲第一久久影院| 久久黄色网页| 欧美视频免费看| 18av网站| 欧美一进一出视频| 日韩在线精品视频| 一区二区三区免费观看| 在线国产日韩| 精品欧美视频| 可以免费看污视频的网站在线| 欧美在线不卡区| 欧美一区二区三区白人| 国产成人丝袜美腿| 久久久久久影院| 日韩av一卡| 成人免费淫片95视频观看网站| 国产欧美日韩精品专区| 欧美日韩中文字幕精品| 亚洲激情图片qvod| 一区二区三区日本| 国产亚洲一区二区在线观看| 国产高清视频一区| www.男人天堂网| 免费试看一区| 久久精品中文字幕一区二区三区| 久久久久久久有限公司| 久久riav二区三区| 中文字幕日韩一区二区三区不卡 | 欧美一二三区在线| 中文字幕av一区二区三区免费看| 国产日韩欧美三级| 在线视频成人| 岛国毛片av在线| 黄色免费在线观看| 成人做爰高清视频网站| 成人在线免费高清视频| 日韩精彩视频| 狠狠色噜噜狠狠狠狠色吗综合| 久久成人18免费网站| 欧美写真视频网站| 日韩欧美一区二区三区久久| www.视频一区| 久久国产精品露脸对白| 欧美电影一二区| 欧美在线资源| 欧美色女视频| 国产精品黄色| 激情另类小说区图片区视频区| 久久婷婷成人综合色| 午夜精彩视频在线观看不卡| 日韩精品极品在线观看播放免费视频| 亚洲黄色天堂| 欧美.com| 国产精品扒开腿做爽爽爽软件| 日韩在线卡一卡二| 成人免费看视频| 欧美一区二区免费观在线| 日韩精品视频在线| 国产精品揄拍一区二区| 国产a级片免费看| 色视频在线播放| 在线观看精品| 日本亚洲一区二区| 中文字幕va一区二区三区| 一区二区三区不卡视频在线观看| 亚洲国产成人午夜在线一区| 一区二区国产视频| 欧美丝袜丝nylons| 亚洲女成人图区| 精品国产一区二区在线| 欧美做爰性生交视频| 国产欧美一区二区三区视频| 福利精品视频| 一本久道久久综合狠狠爱亚洲精品| 九九九九九精品| 中国一区二区三区| 国产精品区在线| 在线视频中文字幕第一页| 成人看片网页| 欧美三区不卡| 国产欧美一区视频|