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

攜程機(jī)票前端Svelte生產(chǎn)實(shí)踐

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

?作者 | shuan feng,攜程高級(jí)前端開發(fā)工程師,關(guān)注性能優(yōu)化、低代碼、svelte等領(lǐng)域。

一、技術(shù)調(diào)研

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

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

在Github上擁有 5w 多的 star!

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

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

去它的官網(wǎng)看一下:

官網(wǎng)上清楚的表明了三大特性:

  • Write less code
  • No virtual DOM
  • Truly reactive

1.1 Write less code

顧名思義,是指實(shí)現(xiàn)相同的功能,Svelte的代碼最少。這一點(diǎn)會(huì)在后面的示例中有所體現(xiàn)。

1.2 No virtual DOM

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

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

其實(shí) Virtual DOM?高效是一個(gè)誤解。說 Virtual DOM? 高效的一個(gè)理由就是它不會(huì)直接操作原生的 DOM? 節(jié)點(diǎn),因?yàn)檫@個(gè)很消耗性能。當(dāng)組件狀態(tài)變化時(shí),它會(huì)通過某些 diff? 算法去計(jì)算出本次數(shù)據(jù)更新真實(shí)的視圖變化,然后只改變需要改變?的 DOM 節(jié)點(diǎn)。

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

組件被重渲染是因?yàn)?nbsp;Vitual DOM? 的高效是建立在 diff? 算法上的,而要有 diff? 一定要將組件重渲染才能知道組件的新狀態(tài)和舊狀態(tài)有沒有發(fā)生改變,從而才能計(jì)算出哪些 DOM 需要被更新。

正是因?yàn)榭蚣鼙旧砗茈y避免無用的渲染,React? 才允許你使用一些諸如 shouldComponentUpdate,PureComponent? 和 useMemo? 的 API 去告訴框架哪些組件不需要被重渲染,可是這也就引入了很多模板代碼。

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

1.3 Truly reactive

第三點(diǎn)真正的響應(yīng)式?,上面也提到了前端框架要解決的首要問題就是:當(dāng)數(shù)據(jù)發(fā)生改變的時(shí)候相應(yīng)的 DOM? 節(jié)點(diǎn)會(huì)被更新,這個(gè)就是reactive。

我們先來看下Vue和React分別是如何實(shí)現(xiàn)響應(yīng)式的。

React reactive

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

React? 開發(fā)者使用 JSX? 語法來編寫代碼,JSX? 會(huì)被編譯成 ReactElement?,運(yùn)行時(shí)生成抽象的 Virtual DOM。

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

Vue reactive

用Vue?實(shí)現(xiàn)同樣的功能。Vue背后又是如何實(shí)現(xiàn)響應(yīng)式的呢?

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

像Vue和React這種實(shí)現(xiàn)響應(yīng)式的方式會(huì)帶來什么問題呢?

  1. diff 機(jī)制為 runtime 帶來負(fù)擔(dān)
  2. 開發(fā)者需自行優(yōu)化性能
  • useMemo
  • useCallback
  • React.memo
  •  ...

那么Svelte又是如何實(shí)現(xiàn)響應(yīng)式的呢?

Svelte reactive

其實(shí)作為一個(gè)框架要解決的問題是當(dāng)數(shù)據(jù)發(fā)生改變的時(shí)候相應(yīng)的 DOM? 節(jié)點(diǎn)會(huì)被更新(reactive?),Virtual DOM? 需要比較新老組件的狀態(tài)才能達(dá)到這個(gè)目的,而更加高效的辦法其實(shí)是數(shù)據(jù)變化的時(shí)候直接更新對應(yīng)的 DOM 節(jié)點(diǎn)。

這就是Svelte?采用的辦法。Svelte?會(huì)在代碼編譯的時(shí)候?qū)⒚恳粋€(gè)狀態(tài)的改變轉(zhuǎn)換為對應(yīng)DOM?節(jié)點(diǎn)的操作,從而在組件狀態(tài)變化的時(shí)候快速高效地對DOM節(jié)點(diǎn)進(jìn)行更新。

深入了解后,發(fā)現(xiàn)它是采用了 Compiler-as-framework? 的理念,將框架的概念放在編譯時(shí)而不是運(yùn)行時(shí)。你編寫的應(yīng)用代碼在用諸如 Webpack? 或 Rollup? 等工具打包的時(shí)候會(huì)被直接轉(zhuǎn)換為 JavaScript? 對 DOM? 節(jié)點(diǎn)的原生操作,從而讓 bundle.js? 不包含框架的 runtime。

那么 Svelte? 到底可以將 bundle size? 減少多少呢?以下是 RealWorld? 這個(gè)項(xiàng)目的統(tǒng)計(jì):

由上面的圖表可以看出實(shí)現(xiàn)相同功能的應(yīng)用,Svelte的bundle size?大小是Vue的1/4?,是React的1/20?!單純從這個(gè)數(shù)據(jù)來看,Svelte?這個(gè)框架對bundle size的優(yōu)化真的很大。

看到這么強(qiáng)有力的數(shù)據(jù)支撐,不得不說真的很動(dòng)心了!

二、項(xiàng)目落地

為了驗(yàn)證Svelte?在營銷 h5 落地的可能,我們選擇了口罩機(jī)項(xiàng)目:

上圖是口罩機(jī)項(xiàng)目的設(shè)計(jì)稿,不難看出,核心邏輯不是很復(fù)雜,這也是我們選用它作為Svelte嘗試的原因。

首先項(xiàng)目的基礎(chǔ)結(jié)構(gòu)是基于svelte-webpack-starter創(chuàng)建的,集成了TypeScript、SCSS、Babel?以及Webpack5?。但這個(gè)基礎(chǔ)模板都只進(jìn)行了簡單的支持,像項(xiàng)目中用到的一些圖片、字體等需要單獨(dú)使用loader去處理。

啟動(dòng)項(xiàng)目,熟悉的hello world:

這里看下核心的

當(dāng)然開發(fā)環(huán)境使用?webpack?有時(shí)不得不說體驗(yàn)不太好,每次都要好幾秒,我們就用Vite?來替代了,基本都是秒開:圖片

Vite的配置也比較簡單:

2.1 組件結(jié)構(gòu)差異

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

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

2.2 生命周期

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

2.3 初始狀態(tài)

接下來是對初始狀態(tài)的定義:

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

2.4 條件判斷

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

Svelte?中則是采用了{(lán)#if conditions}、{:else if}、{/if}?,屬于Svelte?對于HTML的增強(qiáng)。

上面代碼中有這么一行:

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

buttonText?依賴了變量isTextShown?,依賴項(xiàng)變更時(shí)觸發(fā)運(yùn)算,類似Vue?中的computed?,這里的Svelte?使用了$:?關(guān)鍵字來聲明computed變量。

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

2.5 數(shù)據(jù)雙向綁定

項(xiàng)目中有很多地方需要實(shí)現(xiàn)雙向綁定?。我們知道React?是單向數(shù)據(jù)流,所以要手動(dòng)去觸發(fā)變量更新。而Svelte和Vue都是雙向數(shù)據(jù)流。

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

2.6 列表循環(huán)

項(xiàng)目中同樣使用了很多列表循環(huán)渲染。Svelte?使用 {#each items as item}{/each}? 來實(shí)現(xiàn)列表循環(huán)渲染,這里的item?可以通過解構(gòu)賦值,拿到item里面的值。

不得不說有點(diǎn)像ejs

2.7 父子屬性傳遞

父子屬性傳遞時(shí),不同于React?中的props,Svelte? 使用 export? 關(guān)鍵字將變量聲明標(biāo)記為屬性,export? 并不是傳統(tǒng) ES6 的那個(gè)導(dǎo)出,而是一種語法糖寫法。

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

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

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

每個(gè) writable store? 其實(shí)是一個(gè) object?, 在需要用到這個(gè)值的組件里可以 subscribe? 他的變化,然后更新到自己組件里的狀態(tài)。在另一個(gè)組件里可以調(diào)用 set和update 更新這個(gè)狀態(tài)的值。

2.9 路由

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

  • svelte-routing
  • svelte-spa-router

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

而svelte-spa-router?更像vue-router一點(diǎn):

2.10 UI

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

2.11 單元測試

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

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

業(yè)務(wù)代碼遷移完畢,接著就是對原有功能case的逐一驗(yàn)證。

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

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

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

三、實(shí)踐總結(jié)

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

整體來說,Svelte 繼前端三大框架之后推陳出新,以一種新的思路實(shí)現(xiàn)了響應(yīng)式。

因其起步時(shí)間不算很長,國內(nèi)使用程度仍然偏少,目前來說其生態(tài)還不夠完備。

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

另外現(xiàn)在社區(qū)對于Svelte?還有一個(gè)很好的用法是使用它去做Web Component,好處也很明顯:

  • 使用框架開發(fā),更容易維護(hù)
  • 無框架依賴,可實(shí)現(xiàn)跨框架使用
  • 體積小

所以對于想實(shí)現(xiàn)跨框架組件復(fù)用的團(tuán)隊(duì),用Svelte?去做Web Component也是一個(gè)很好的選擇。

責(zé)任編輯:未麗燕 來源: 攜程技術(shù)
相關(guān)推薦

2022-05-13 09:27:55

Widget機(jī)票業(yè)務(wù)App

2020-12-04 14:32:33

AndroidJetpackKotlin

2023-05-12 10:14:38

APP開發(fā)

2023-08-25 09:51:21

前端開發(fā)

2025-06-24 09:51:47

2017-04-11 15:11:52

ABtestABT變量法

2022-06-10 08:35:06

項(xiàng)目數(shù)據(jù)庫攜程機(jī)票

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系統(tǒng)機(jī)票前臺(tái)微服務(wù)架構(gòu)

2017-01-10 16:04:02

容器MySQL實(shí)踐

2022-06-27 09:36:29

攜程度假GraphQL多端開發(fā)

2017-04-11 15:34:41

機(jī)票前臺(tái)埋點(diǎn)

2025-07-11 09:09:00

2023-09-05 07:40:37

PythonSDKAPI

2022-07-15 12:58:02

鴻蒙攜程華為

2021-03-12 07:47:44

KubernetesRedis-clustRedis

2023-07-12 16:07:50

鏈路數(shù)據(jù)湖技術(shù)

2017-03-15 17:38:19

互聯(lián)網(wǎng)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

国产高清不卡一区| 91欧美大片| 疯狂做受xxxx高潮欧美日本| 九色91视频| 国产情侣免费视频| 国产精品99久久久久久动医院| 91.成人天堂一区| 免费的一级黄色片| 蜜芽tv福利在线视频| 日韩高清国产一区在线| 亚洲全黄一级网站| 九九九九九九九九| 天堂av在线网| 国产精品入口麻豆九色| 成人午夜电影在线播放| 亚洲大尺度在线观看| 欧美一区精品| 亚洲嫩模很污视频| 波多野结衣网页| 久久uomeier| 一卡二卡三卡日韩欧美| 欧美男人的天堂| www.久久成人| 美女尤物国产一区| 777午夜精品福利在线观看| 国产精品无码无卡无需播放器| 在线观看视频一区二区三区| 在线视频国内自拍亚洲视频| 国产 欧美 日韩 一区| 国产精品毛片一区二区三区四区| 国产精品一二三区| 国产高清在线不卡| 久久精品视频6| 天天影视综合| 亚洲天堂男人的天堂| 日本人妻一区二区三区| www.一区| 91福利小视频| 亚洲熟女乱色一区二区三区| 天堂av中文在线| 中文字幕亚洲一区二区va在线| 鲁鲁视频www一区二区| 亚洲黄色在线免费观看| 精品一区二区成人精品| 国产精品久久久久久久午夜| 国产91精品一区| 激情欧美日韩| 欧美精品情趣视频| 久久精品一区二区三区四区五区| 国产不卡一二三区| 亚洲国产小视频| 日本50路肥熟bbw| 自拍偷拍欧美日韩| 欧美日韩不卡在线| 色播五月激情五月| 成人一级视频| 欧美日韩另类一区| 美女一区二区三区视频| av有声小说一区二区三区| 欧美色视频日本高清在线观看| 国产a级片网站| 青春草在线免费视频| 亚洲男人的天堂av| 2025韩国大尺度电影| 网友自拍视频在线| 国产精品毛片无遮挡高清| 日韩久久在线| 95在线视频| 中文字幕一区视频| 在线观看国产一区| 精品黄色免费中文电影在线播放| 国产精品毛片a∨一区二区三区| 日韩精品久久久| 日本视频在线观看| 亚洲乱码一区二区三区在线观看| 99re8这里只有精品| 自拍亚洲图区| 亚洲午夜久久久久中文字幕久| 国产 欧美 日韩 一区| 91超碰在线| 欧美特级www| 国产熟人av一二三区| 国产91在线精品| 88在线观看91蜜桃国自产| 午夜激情视频网| 91蜜桃臀久久一区二区| 亚洲成人黄色在线| 大又大又粗又硬又爽少妇毛片| 精品国产一区二区三区| 久久天堂电影网| 久一区二区三区| 亚洲一区二区成人| 国产精品一区二区三区成人| 国产手机精品视频| 成人免费黄色在线| 欧美一区二区三区在线免费观看 | 免费亚洲一区| 国产精品欧美久久久| 国产免费不卡视频| 成人福利视频网站| 欧美日韩精品免费看| 麻豆传媒在线观看| 亚洲电影激情视频网站| 丁香啪啪综合成人亚洲| 99亚洲男女激情在线观看| 欧美精品一区二区久久久| 男人的天堂官网| 欧美日韩国产一区精品一区| 清纯唯美日韩制服另类| 91精品国产乱码久久久久| 成+人+亚洲+综合天堂| 日韩av不卡播放| 日韩另类在线| 91久久国产最好的精华液| 黄色片子免费看| 国产成人1区| 久久久久久av| 在线免费观看中文字幕| av亚洲精华国产精华精华| 一区二区免费在线观看| 92久久精品| 欧美挠脚心视频网站| 日本japanese极品少妇| 99热在线成人| 国产精品第1页| 亚洲女人18毛片水真多| 国产精品美女久久久久久久| 成人中文字幕在线播放| 亚洲性视频在线| 国产午夜精品全部视频在线播放| 久久一区二区三| 久久精品国产亚洲一区二区三区| 久久国产精品久久精品国产| 污污视频在线| 56国语精品自产拍在线观看| 人妻无码一区二区三区| 午夜电影亚洲| 成人福利网站在线观看| 国产人成在线观看| 欧美午夜宅男影院在线观看| 精品国产免费久久久久久婷婷| 97精品97| 国产精品久久久久久久久久久久| 青青草视频免费在线观看| 亚洲一区二区美女| 国产在线a视频| **女人18毛片一区二区| 国产精品欧美激情在线播放| 国产区在线视频| 日本韩国精品一区二区在线观看| 亚洲AV无码国产精品| 亚洲国产精品第一区二区| 91香蕉亚洲精品| 麻豆视频在线| 欧美日韩激情一区| 又色又爽的视频| 麻豆成人av在线| 亚洲一区二区在线免费观看| 成人精品动漫| 日韩一区二区久久久| 在线播放国产一区| 国产精品久久久久一区二区三区 | 午夜激情视频在线播放| 蜜臀av性久久久久蜜臀aⅴ四虎 | 午夜精品一区二区三区国产| 国产精品一区二区电影| 麻豆传媒免费在线观看| 337p亚洲精品色噜噜狠狠| 91麻豆免费视频网站| 国产一区在线观看视频| 成年丰满熟妇午夜免费视频| 精品一区二区三区中文字幕视频 | 日韩av一级片| 亚洲人成77777| 伊人久久大香| 欧美日本在线视频中文字字幕| www.久久精品.com| 五月婷婷久久综合| 香蕉网在线播放| 日韩国产欧美一区二区三区| 亚洲在线不卡| 日韩一区二区三区精品| 午夜精品理论片| 男女污污视频在线观看| 欧美性受xxxx黑人xyx性爽| 国产又粗又长又黄的视频| 国产一区二区三区在线看麻豆| 人人妻人人澡人人爽欧美一区| 美日韩黄色大片| 日本乱人伦a精品| 日本精品在线| 亚洲精品一区二区三区影院| 免费污污视频在线观看| 亚洲三级在线看| 亚洲色图14p| 免费在线看成人av| www.一区二区.com| 中国av一区| 亚洲精品日韩av| 综合久久2023| 欧美成年人视频网站欧美| 香蕉视频免费在线看| 欧美日韩亚洲综合在线| 国产精品二区一区二区aⅴ| 久久综合久久99| 亚欧精品在线视频| 久久av最新网址| 精品一区二区三区毛片| 亚洲欧美日本伦理| 91在线短视频| aaaa欧美| 69精品小视频| aaa大片在线观看| 国产亚洲精品va在线观看| 黑人精品一区二区| 欧美日韩国产中文| 国产 日韩 欧美 在线| 亚洲欧美日韩一区二区| 国产全是老熟女太爽了| 成人精品在线视频观看| 制服丝袜综合网| 一本色道久久综合亚洲精品不卡| 三级网在线观看| 欧美日一区二区| 精品欧美一区二区久久久伦| 日韩影片在线观看| 国产精品丝袜高跟| 一个人www视频在线免费观看| 大量国产精品视频| youjizz在线播放| 日韩精品中文字幕久久臀| 亚洲成人黄色片| 欧美美女喷水视频| 波多野结衣一本一道| 欧美日韩国产黄| 久久综合色综合| 亚洲精品一二三四区| av最新在线观看| 中文av字幕一区| xxxx日本免费| ww久久中文字幕| 亚洲一区二区三区黄色| 国产精品一区二区不卡| 在线能看的av网站| 美女爽到高潮91| 狠狠热免费视频| 日韩精品欧美精品| 粉嫩虎白女毛片人体| 久久国产精品毛片| 日本成年人网址| 鲁大师成人一区二区三区| 国产中文字幕在线免费观看| 亚洲日韩成人| 国产极品在线视频| 亚洲免费激情| koreanbj精品视频一区| 国产精品日本| 国产在线观看福利| 久久国产精品久久久久久电车| 精品中文字幕av| 麻豆精品网站| 熟女人妇 成熟妇女系列视频| 丝袜亚洲另类丝袜在线| 人人干人人视频| 日本在线不卡视频| 三级av免费观看| 久久99精品国产麻豆婷婷洗澡| 中文字幕在线视频精品| 精品一区二区日韩| 免费观看黄网站| 床上的激情91.| 第四色在线视频| 久久久亚洲高清| 国产福利在线导航| 亚洲免费av观看| 国产精品美女毛片真酒店| 黑丝美女久久久| 精品乱码一区内射人妻无码| 51精品视频一区二区三区| av中文在线观看| 日韩av在线看| chinese偷拍一区二区三区| 欧美成人性生活| 理论片午夜视频在线观看| 国产91av在线| 欧美黄色网络| 成人免费看片网址| 综合色就爱涩涩涩综合婷婷| 亚洲视频电影| 亚洲经典在线看| 成人黄色一区二区| 国产成人精品综合在线观看| 日韩片在线观看| 中文字幕一区二区三区不卡在线| 国产精品30p| 欧洲生活片亚洲生活在线观看| 国产精品爽爽久久久久久| 欧美精品一区二区三区久久久| 国产在线资源| 色综合天天狠天天透天天伊人| 亚洲女同av| 99re视频在线播放| 国产精品免费99久久久| 成人国产在线看| 免费人成黄页网站在线一区二区| 成人做爰69片免费| 亚洲国产激情av| 国产精品suv一区二区| 欧美亚洲国产一区在线观看网站 | 日韩电影天堂视频一区二区| 影视亚洲一区二区三区| www.亚洲天堂网| 国产激情一区二区三区| av网站免费在线看| 亚洲一区二区四区蜜桃| 最近中文字幕免费观看| 亚洲精品一区二区三区香蕉| 欧美黄色激情| 日韩美女免费视频| 成人自拍在线| 99亚洲精品视频| 日韩成人精品在线观看| fc2成人免费视频| 综合久久久久久| 一级特黄aa大片| 伊人精品在线观看| 自拍视频在线看| 国产精品乱子乱xxxx| 911久久香蕉国产线看观看| 国产裸体舞一区二区三区| 高清免费成人av| 国产极品美女在线| 欧美日韩精品一区二区在线播放| 少妇性bbb搡bbb爽爽爽欧美| 欧美精品www| 视频二区欧美毛片免费观看| 中文字幕一区二区三区四区五区六区| 老司机午夜精品视频在线观看| 性久久久久久久久久久| 亚洲综合视频网| 成人精品在线播放| 欧美成人激情视频| 91麻豆精品国产综合久久久 | 亚洲成人精品| 亚洲成人福利在线| 国产精品视频看| 中文字幕欧美在线观看| 国产亚洲视频在线| 激情都市亚洲| 日韩电影免费观看在| 三级久久三级久久| 69视频在线观看免费| 欧美伊人久久大香线蕉综合69| 黄色av网站在线免费观看| 日本三级韩国三级久久| 亚洲综合福利| 国语对白做受xxxxx在线中国| 久久综合久久鬼色中文字| 国产一级片毛片| 亚洲日本成人女熟在线观看| 国偷自产一区二区免费视频| 欧美日韩在线一区二区三区| 久久一区亚洲| 国产成人免费观看网站| 欧美日韩一卡二卡三卡| 天堂а√在线资源在线| 91网在线免费观看| 一区在线视频| 性久久久久久久久久| 日本韩国精品在线| 91成人高清| 91精品国产一区二区三区动漫| 中文无码久久精品| 国产精品嫩草69影院| 午夜精品久久久久久久久久久 | 国产一区二区三区在线| 成人福利一区二区| 丰满人妻一区二区三区53号| 国产69精品久久久久毛片| 国产无遮挡呻吟娇喘视频| 亚洲偷熟乱区亚洲香蕉av| 亚洲aⅴ网站| 欧美激情亚洲天堂| 久久久久久久综合色一本| 国产一区二区在线播放视频| 欧美丰满少妇xxxx| 西野翔中文久久精品字幕| 九九热在线免费| 一区二区三区四区乱视频| 无码精品人妻一区二区三区影院 | 中文幕av一区二区三区佐山爱| 亚洲色欲久久久综合网东京热| 久久女同性恋中文字幕| 国产精品国产一区二区三区四区 | 欧美人妻精品一区二区三区 | 色综合久久久久综合99| 日本天堂在线观看| 精品国产免费人成电影在线观... 精品国产免费久久久久久尖叫 | 99riav视频在线观看| 先锋影音一区二区三区|