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

如何優化前端性能?

開發 前端
隨著前端的范疇逐漸擴大,深度逐漸下沉,富前端必然帶來的一個問題就是性能。特別是在大型復雜項目中,重前端業務可能因為一個小小的數據依賴,導致整個頁面卡頓甚至崩潰。

 隨著前端的范疇逐漸擴大,深度逐漸下沉,富前端必然帶來的一個問題就是性能。特別是在大型復雜項目中,重前端業務可能因為一個小小的數據依賴,導致整個頁面卡頓甚至崩潰。本文基于Quick BI(數據可視化分析平臺)歷年架構變遷中性能的排查、解決和總結出的“個性”問題,嘗試總結整個前端層面相對“共性”的問題,提供一些前端性能解決思路。

[[346642]]

一 引發性能問題原因?

引發性能問題的原因通常不是單方面緣由,特別是大型系統迭代多年后,長期積勞成疾造成,所以我們要必要分析找到癥結所在,并按瓶頸優先級逐個擊破,拿我們項目為例,大概分幾個方面:

1 資源包過大

通過Chrome DevTools的Network標簽,我們可以拿到頁面實際拉取的資源大小(如下圖):

 

 

 

 

 

經過前端高速發展,近幾年項目更新迭代,前端構建產物也在急劇增大,因為要業務先行,很多同學引入庫和編碼過程并沒有考慮性能問題,導致構建的包增至幾十MB,這樣帶來兩個顯著的問題:

  • 弱(普通)網絡下,首屏資源下載耗時長
  • 資源解壓解析執行慢

對于第一個問題,基本上會影響所有移動端用戶,并且會耗費大量不必要的用戶帶寬,對客戶是一個經濟上的隱式損失和體驗損失。

對于第二個問題,會影響所有用戶,用戶可能因為等待時間過長而放棄使用。

下圖展示了延遲與用戶反應:

 

 

 

 

 

2 代碼耗時長

在代碼執行層面,項目迭代中引發的性能問題普遍是因為開發人員編碼質量導致,大概以下幾個緣由:

不必要的數據流監聽

此場景在hooks+redux的場景下會更容易出現,如下代碼:

 

  1. const FooComponent = () => { 
  2.   const data = useSelector(state => state.fullData); 
  3.   return <Bar baz={data.bar.baz} />; 
  4. }; 

假設fullData是頻繁變更的大對象,雖然FooComponent僅依賴其.bar.baz屬性,fullData每次變更也會導致Foo重新渲染。

雙刃劍cloneDeep

相信很多同學在項目中都有cloneDeep的經歷,或多或少,特別是迭代多年的項目,其中難免有mutable型數據處理邏輯或業務層面依賴,需要用到cloneDeep,但此方法本身存在很大性能陷阱,如下:

 

  1. // a.tsx 
  2. export const a = { 
  3.     name'a'
  4. }; 
  5. // b.tsx 
  6. import { a } = b; 
  7. saveData(_.cloneDeep(a)); // 假設需要克隆后落庫到后端數據庫 

上方代碼正常迭代中是沒有問題的,但假設哪天 a 需要擴展一個屬性,保存一個ReactNode的引用,那么執行到b.tsx時,瀏覽器可能直接崩潰!

Hooks之Memo

hooks的發布,給react開發帶來了更高的自由度,同時也帶來了容易忽略的質量問題,由于不再有類中明碼標價的生命周期概念,組件狀態需要開發人員自由控制,所以開發過程中務必懂得react對hooks組件的渲染機制,如下代碼可優化的地方:

 

  1. const Foo = () => { // 1. Foo可用React.memo,避免無props變更時渲染 
  2.     const result = calc(); // 2. 組件內不可使用直接執行的邏輯,需要用useEffect等封裝 
  3.     return <Bar result={result} />; // 3.render處可用React.useMemo,僅對必要的數據依賴作渲染 
  4. }; 

Immutable Deep Set

在使用數據流的過程中,很大程度我們會依賴lodash/fp的函數來實現immutable變更,但fp.defaultsDeep系列函數有個弊端,其實現邏輯相當于對原對象作深度克隆后執行fp.set,可能帶來一些性能問題,并且導致原對象所有層級屬性都被變更,如下:

 

  1. const a = { b: { c: { d: 123 }, c2: { d2: 321 } } }; 
  2. const merged = fp.defaultsDeep({ b: { c3: 3 } }, a); 
  3. console.log(merged.b.c === a.b.c); // 打印 false 

3 排查路徑

對于這些問題來源,通過Chrome DevTools的Performance火焰圖,我們可以很清晰地了解整個頁面加載和渲染流程各個環節的耗時和卡頓點(如下圖):

 

 

 

 

當我們鎖定一個耗時較長的環節,就可以再通過矩陣樹圖往下深入(下圖),找到具體耗時較長的函數。

 

 

 

 

誠然,通常我們不會直接找到某個單點函數占用耗時非常長,而基本是每個N毫秒函數疊加執行成百上千次導致卡頓。所以這塊結合react調試插件的Profile可以很好地幫助定位渲染問題所在:

 

 

 

 

如圖react組件被渲染的次數以及其渲染時長一目了然。

二 如何解決性能問題?

1 資源包分析

作為一名有性能sense的開發者,有必要對自己構建的產物內容保持敏感,這里我們使用到webpack提供的stats來作產物分析。

首先執行 webpack --profile --json > ./build/stats.json 得到 webpack的包依賴分析數據,接著使用 webpack-bundle-analyzer ./build/stats.json 即可在瀏覽器看到一張構建大圖(不同項目產物不同,下圖僅作舉例):

 

 

 

 

當然,還有一種直觀的方式,可以采用Chrome的Coverage功能來輔助判定哪些代碼被使用(如下圖):

 

 

 

 

紅色表示未執行過的代碼

最佳構建方式

通常來講,我們組織構建包的基本思路是:

  • 按entry入口構建。
  • 一個或多個共享包供多entry使用。

而基于復雜業務場景的思路是:

  • entry入口輕量化。
  • 共享代碼以chunk方式自動生成,并建立依賴關系。
  • 大資源包動態導入(異步import)。

webpack 4中提供了新的插件 splitChunks 來解決代碼分離優化的問題,它的默認配置如下:

 

  1. module.exports = { 
  2.     //... 
  3.     optimization: { 
  4.         splitChunks: { 
  5.             chunks: 'async'
  6.             minSize: 20000, 
  7.             minRemainingSize: 0, 
  8.             maxSize: 0, 
  9.             minChunks: 1, 
  10.             maxAsyncRequests: 30, 
  11.             maxInitialRequests: 30, 
  12.             automaticNameDelimiter: '~'
  13.             enforceSizeThreshold: 50000, 
  14.             cacheGroups: { 
  15.                 defaultVendors: { 
  16.                     test: /[\\/]node_modules[\\/]/, 
  17.                     priority: -10 
  18.                 }, 
  19.                 default: { 
  20.                     minChunks: 2, 
  21.                     priority: -20, 
  22.                     reuseExistingChunk: true 
  23.                 } 
  24.             } 
  25.         } 
  26.     } 
  27. }; 

根據上述配置,其分離chunk的依據有以下幾點:

  • 模塊被共享或模塊來自于node_modules。
  • chunk必須大于20kb。
  • 同一時間并行加載的chunk或初始包不得超過30。

理論上webpack默認的代碼分離配置已經是最佳方式,但如果項目復雜或耦合程度較深,仍然需要我們根據實際構建產物大圖情況,調整我們的chunk split配置。

解決TreeShaking失效

“你項目中有60%以上的代碼并沒有被使用到!”

treeshaking的初衷便是解決上面一句話中的問題,將未使用的代碼移除。

webpack默認生產模式下會開啟treeshaking,通過上述的構建配置,理論上應該達到一種效果“沒有被使用到的代碼不應該被打入包中”,而現實是“你認為沒有被使用的代碼,全部被打入Initial包中”,這個問題通常會在復雜項目中出現,其緣由就是代碼副作用(code effects)。由于webpack無法判定某些代碼是否“需要產生副作用”,所以會將此類代碼打入包中(如下圖):

 

 

 

 

所以,你需要明確知道你的代碼是否有副作用,通過這句話判定:“關于‘副作用’的定義是,在導入時會執行特殊行為的代碼(修改全局對象、立即執行的代碼等),而不是僅僅暴露一個 export 或多個 export。舉例說明,例如 polyfill,它影響全局作用域,并且通常不提供 export。”

對此,解決方法就是告訴webpack我的代碼沒有副作用,沒有被引入的情況下可以直接移除,告知的方式即:

  • 在package.json中標記sideEffects為false。
  • 或 在webpack配置中 module.rules 添加sideEffects過濾。

模塊規范

由此,要使得構建產物達到最佳效果,我們在編碼過程中約定了以下幾點模塊規范:

  • [必須] 模塊務必es6 module化(即export 和 import)。
  • [必須] 三方包或數據文件(如地圖數據、demo數據)超過 400KB 必須動態按需加載(異步import)。
  • [禁止] 禁止使用export * as方式輸出(可能導致tree-shaking失效并且難以追溯)。
  • [推薦] 盡可能引入包中具體文件,避免直接引入整個包(如:import { Toolbar } from '@alife/foo/bar')。
  • [必須] 依賴的三方包必須在package.json中標記為sideEffects: false(或在webpack配置中標記)。

2 Mutable數據

基本上通過Performance和React插件提供的調試能力,我們基本可以定位問題所在。但對于mutable型的數據變更,我這里也結合實踐給出一些非標準調試方式:

凍結定位法

眾所周知,數據流思想的產生緣由之一就是避免mutable數據無法追溯的問題(因為你無法知道是哪段代碼改了數據),而很多項目中避免不了mutable數據更改,此方法就是為了解決一個棘手的mutable數據變更問題而想出的方法,這里我暫時命名為“凍結定位法”,因為原理就是使用凍結方式定位mutable變更問題,使用相當tricky:

 

  1. constob j= { 
  2.     prop: 42 
  3. }; 
  4.  
  5. Object.freeze(obj); 
  6.  
  7. obj.prop=33; // Throws an error in strict mode 

Mutable追溯

此方法也是為了解決mutable變更引發數據不確定性變更問題,用于實現排查的幾個目的:

  • 屬性在什么地方被讀取。
  • 屬性在什么地方被變更。
  • 屬性對應的訪問鏈路是什么。

如下示例,對于一個對象的深度變更或訪問,使用 watchObject 之后,不管在哪里設置其屬性的任何層級,都可以輸出變更相關的信息(stack內容、變更內容等):

 

  1. const a = { b: { c: { d: 123 } } }; 
  2. watchObject(a); 
  3. const c =a.b.c; 
  4. c.d =0; // Print: Modify: "a.b.c.d" 

watchObject 的原理即對一個對象進行深度 Proxy 封裝,從而攔截get/set權限,詳細可參考: https://gist.github.com/wilsoncook/68d0b540a0fea24495d83fc284da9f4b

避免Mutable

通常像react這種技術棧,都會配套使用相應的數據流方案,其與mutable是天然對立的,所以在編碼過程中應該盡可能避免mutable數據,或者將兩者從設計上分離(不同store),否則出現不可預料問題且難以調試

3 計算&渲染

最小化數據依賴

在項目組件爆炸式增長的情況下,數據流store內容層級也逐漸變深,很多組件依賴某個屬性觸發渲染,這個依賴項需要盡可能在設計時遵循最小化原則,避免像上方所述,依賴一個大的屬性導致頻繁渲染。

合理利用緩存

(1)計算結果

在一些必要的cpu密集型計算邏輯中,務必采用 WeakMap 等緩存機制,存儲當前計算終態結果或中間狀態。

(2)組件狀態

對于像hooks型組件,有必要遵循以下兩個原則:

  • 盡可能memo耗時邏輯。
  • 無多余memo依賴項。

避免cpu密集型函數

某些工具類函數,其復雜度跟隨入參的量級上升,而另外一些本身就會耗費大量cpu時間。針對這類型的工具,要盡量避免使用,若無法避免,也可通過 “控制入參內容(白名單)” 及 “異步線程(webworker等)”方式做到嚴控。

比如針對 _.cloneDeep ,若無法避免,則要控制其入參屬性中不得有引用之類的大型數據。

另外像最上面描述的immutable數據深度merge的問題,也應該盡可能控制入參,或者也可參考使用自研的immutable實現:https://gist.github.com/wilsoncook/fcc830e5fa87afbf876696bf7a7f6bb1

 

  1. const a = { b: { c: { d: 123 }, c2: { d2: 321 } } }; 
  2. const merged = immutableDefaultsDeep(a, { b: { c3: 3 } }); 
  3. console.log(merged === a); // 打印 false 
  4. console.log(merged.b.c === a.b.c); // 打印 true 

三 寫在最后

以上,總結了Quick BI性能優化過程中的部分心得和經驗,性能是每個開發者不可繞過的話題,我們的每段代碼,都對標著產品的健康度。

責任編輯:華軒 來源: 阿里技術
相關推薦

2020-10-16 10:40:39

前端性能可視化

2022-11-16 12:03:13

性能優化前端

2022-05-17 09:02:30

前端性能優化

2019-11-01 14:00:58

前端性能優化代碼

2021-05-31 08:30:50

監控網站性能

2022-03-02 11:13:50

Web前端開發

2021-07-05 14:55:28

前端優化圖片

2023-04-10 11:18:38

前端性能優化

2021-02-02 13:45:31

Vue代碼前端

2012-01-10 16:22:25

Web

2013-01-22 15:27:23

WebWeb前端

2020-03-09 16:43:06

腳本語言瀏覽器JavaScript

2022-01-09 16:45:36

前端性能優化編程

2023-10-18 10:38:53

API

2022-09-13 12:56:28

前端優化

2020-08-24 07:12:17

前端CRP性能優化

2023-12-14 17:21:28

前端性能優化

2020-03-31 14:16:25

前端性能優化HTTP

2019-07-29 10:39:39

前端性能優化緩存

2011-03-01 17:26:48

WLAN優化
點贊
收藏

51CTO技術棧公眾號

亚洲xxxx在线| 亚洲激情在线视频| 日韩精品第1页| 精品人妻久久久久一区二区三区| 亚洲精品美女91| 亚洲天堂色网站| 少妇丰满尤物大尺度写真| 在线免费三级电影网站| 日韩一区欧美小说| 国产伦精品一区二区三区视频孕妇| 在线永久看片免费的视频| 午夜激情久久| 日韩精品在线观| 污视频网址在线观看| 岛国毛片av在线| 欧美韩国日本不卡| 国产精品免费区二区三区观看 | 97婷婷大伊香蕉精品视频| 女~淫辱の触手3d动漫| 精品一区二区三区四区五区| 欧美日韩免费看| 欧美aaa在线观看| 欧洲成人av| 国产精品18久久久久久久久| 国产精品久久一| 日韩免费av片| 中文字幕午夜精品一区二区三区| 国产视频精品一区二区三区| 美女被艹视频网站| 日本黄色一区| 欧美日韩亚洲91| 日本一级黄视频| 日本a在线播放| 国产欧美日韩亚州综合| 国产一区在线免费观看| 性少妇videosexfreexxx片| 日本成人在线电影网| 91禁外国网站| 国产精品变态另类虐交| 永久91嫩草亚洲精品人人| 国产一区二区三区视频在线观看 | 久久这里只有精品视频网| 亚洲最大的网站| 国产精品伦理一区| 免费人成网站在线观看欧美高清| 26uuu另类亚洲欧美日本老年| 免费视频一二三区| 影音先锋日韩精品| 久久亚洲精品中文字幕冲田杏梨 | 国产一区二区电影在线观看| 亚洲精品国产综合区久久久久久久| 亚洲欧美一区二区三区不卡| 亚洲欧洲一二区| 欧美日本韩国一区二区三区视频| 国产精品少妇在线视频| 东京一区二区| 色婷婷av一区二区三区之一色屋| 春日野结衣av| 樱桃视频成人在线观看| 懂色aⅴ精品一区二区三区蜜月| 91成人在线观看喷潮教学| 乱馆动漫1~6集在线观看| 午夜视频在线观看一区| 国产视频一视频二| 在线观看爽视频| 色呦呦国产精品| 丁香婷婷激情网| 91在线成人| 欧美美女一区二区| 黄大色黄女片18第一次| 一级欧美视频| 日韩精品一区二区三区中文不卡| 18禁一区二区三区| 久久久久久毛片免费看| 精品视频在线导航| 国产精品无码无卡无需播放器| 成人精品影院| 另类少妇人与禽zozz0性伦| 欧美毛片在线观看| 亚洲在线成人| 国产精品久久久久久亚洲调教 | 青青草成人免费| 亚洲日本欧美| 奇米四色中文综合久久| 国产91av在线播放| 国产一区二区三区黄视频 | aaaaaaaa毛片| 欧美wwwwww| 亚洲最新av网址| 午夜剧场免费在线观看| 欧美黄免费看| 国产精品18久久久久久麻辣| 亚洲永久精品视频| 粉嫩蜜臀av国产精品网站| 你懂的网址一区二区三区| www.黄在线观看| 一区二区免费视频| 116极品美女午夜一级| 91成人精品观看| 亚洲精品国产美女| 国产极品美女在线| 久久国产精品久久w女人spa| 91中文精品字幕在线视频| 少妇人妻偷人精品一区二区| 国产清纯在线一区二区www| 欧美少妇一区二区三区| 日韩电影大全网站| 日韩欧美123| 成人黄色免费网址| 亚洲国产99| 国产拍精品一二三| 色视频在线观看福利| 日韩一区有码在线| 日日碰狠狠躁久久躁婷婷| 精品国产乱码一区二区三区| 亚洲免费av片| 国产在线观看免费av| 美女视频黄a大片欧美| 国产伦精品一区二区三区高清 | 好吊妞国产欧美日韩免费观看网站| 国产亚洲一级高清| 四虎成人精品永久免费av| 国内精品久久久久影院薰衣草| 久久精品日产第一区二区三区乱码| 成人免费观看视频大全| 欧美中文字幕不卡| 免费a级黄色片| 欧美日韩午夜| 91精品啪aⅴ在线观看国产| 国产黄在线观看| 第一福利永久视频精品| 久久久高清视频| 欧美激情综合色综合啪啪| 国产在线一区二区三区| 岛国在线视频| 色偷偷88欧美精品久久久| 99久久人妻精品免费二区| 欧美日本三区| 亚洲aa中文字幕| 日本视频在线播放| 欧美午夜片在线看| 男人天堂av电影| 午夜在线视频一区二区区别 | 亚洲乱码国产乱码精品精软件| 国产精品国产三级国产普通话99 | 国产视频久久久| 免费在线一级片| 国产精品99久久久久久有的能看| 在线国产精品网| 免费视频观看成人| 日韩中文第一页| 一级黄色小视频| 国产精品视频观看| 最新天堂在线视频| 久久国产小视频| 国产在线观看精品| a天堂中文在线官网在线| 555www色欧美视频| 国产97免费视频| 国产成人av电影| 日本免费成人网| 一区二区三区四区视频免费观看| 九九九热精品免费视频观看网站| 亚洲国产日韩在线观看| 亚洲二区在线观看| 中文在线永久免费观看| 性伦欧美刺激片在线观看| 欧美日韩在线一区二区三区| 亚洲a∨精品一区二区三区导航| 国产一区二区三区毛片| 国产一区二区女内射| 亚洲精品成人天堂一二三| 精品人妻二区中文字幕| 中文欧美日韩| 日韩国产欧美精品| 国产激情综合| 欧美激情xxxx性bbbb| 免费福利在线视频| 欧美精品xxxxbbbb| 久久黄色免费网站| 久久综合999| 在线黄色免费看| 国产精品啊啊啊| 久久久神马电影| 99热播精品免费| 欧美日本中文字幕| 日韩电影网址| 91麻豆精品国产自产在线| 日韩高清免费av| 国产精品伦理在线| 美女黄色一级视频| 日日噜噜夜夜狠狠视频欧美人| 一区二区三区精品国产| 国产三级精品三级在线观看国产| 日本高清+成人网在线观看| 老司机99精品99| 亚洲国产精品人人爽夜夜爽| 国产天堂第一区| 一区二区三区欧美日| 91精品人妻一区二区| 激情欧美日韩一区二区| 九色在线视频观看| 久久久人成影片免费观看| 久久影院理伦片| 疯狂欧洲av久久成人av电影| 欧美最猛性xxxxx免费| 国产激情视频在线| 国产亚洲精品成人av久久ww| 国产激情无套内精对白视频| 色爱区综合激月婷婷| 我家有个日本女人| 中文乱码免费一区二区| 日本不卡视频一区| 激情文学综合插| 免费在线观看的毛片| 一区久久精品| 色香蕉在线观看| 国产中文字幕一区二区三区| 国产伦精品一区二区三区| 国产一区二区三区免费观看在线| 国产不卡视频在线| 嗯~啊~轻一点视频日本在线观看| 日韩中文字幕在线精品| 国产在线网站| 精品调教chinesegay| 狠狠躁日日躁夜夜躁av| 欧美一区二区网站| 亚洲天堂国产精品| 日本道精品一区二区三区| 久久草视频在线| 亚洲一区二区三区视频在线播放 | 毛片在线免费| 亚洲成人网在线| www.色播.com| 欧美一区二区三区在线观看| 中文字幕在线日亚洲9| 色综合天天视频在线观看| 欧美三级韩国三级日本三斤在线观看 | 亚洲视频久久| 第九区2中文字幕| 久久久人成影片免费观看| 亚洲综合欧美日韩| 欧美色蜜桃97| 手机成人在线| 欧美一站二站| 亚欧洲精品在线视频免费观看| 欧美猛男男男激情videos| 久久综合一区二区三区| 天天躁日日躁成人字幕aⅴ| 精品一区二区三区国产| 日韩欧美美女在线观看| 久99久在线| 天天操综合520| 日本黄网免费一区二区精品| 久久99高清| 五月天久久综合网| 99久久婷婷国产综合精品电影√| 亚洲三区四区| 66视频精品| 免费cad大片在线观看| 欧美伊人久久| 日韩视频在线视频| 999在线观看精品免费不卡网站| 国产一区二区视频播放| 欧美专区18| a在线观看免费视频| 精彩视频一区二区三区| 精产国品一区二区三区| www.亚洲国产| 波多野吉衣中文字幕| 中文字幕不卡在线观看| 黄色录像一级片| 亚洲在线中文字幕| 国产香蕉视频在线| 91久久精品一区二区三区| 在线观看xxxx| 日韩免费性生活视频播放| 五月婷在线视频| 在线电影av不卡网址| 黄黄的网站在线观看| 久久久久久国产免费| a日韩av网址| 国产专区欧美专区| 高潮按摩久久久久久av免费| 欧美成人在线免费观看| 久久国产亚洲| 免费一级特黄毛片| 蜜臀va亚洲va欧美va天堂| 欧美性受xxxxxx黑人xyx性爽| 成人性生交大片免费看中文网站| 免费观看av网站| 亚洲欧美偷拍三级| 九九热精品视频在线| 欧美美女bb生活片| 婷婷在线免费视频| 日韩在线免费观看视频| 岛国在线视频网站| 91久久精品一区| 五月激激激综合网色播| 男人的天堂成人| 香蕉久久国产| 日本黄色www| 国产无人区一区二区三区| 免费在线视频观看| 欧美性感一区二区三区| 特黄特色免费视频| 欧美日韩激情| 成人免费看片视频在线观看| 宅男噜噜噜66国产日韩在线观看| 天堂一区在线观看| 91亚洲精品一区二区乱码| 多男操一女视频| 日韩欧美国产激情| 亚洲第一视频在线播放| 一区二区三区高清国产| 3344国产永久在线观看视频| 国产欧美日韩91| 啄木系列成人av电影| a级免费在线观看| 激情图区综合网| 欧美另类z0zx974| 欧美日韩国产精品一区| www.亚洲天堂.com| 精品国模在线视频| 99re66热这里只有精品4| 国内精品视频在线播放| 欧美精品二区| 午夜天堂在线视频| 中文字幕欧美激情一区| 天堂中文字幕在线观看| 亚洲第一网中文字幕| av小次郎在线| 91久久久精品| 97精品在线| 怡红院亚洲色图| 中文av一区特黄| 波多野结衣视频在线看| 精品丝袜一区二区三区| 天天综合av| 精品久久久久久一区二区里番| 好吊视频一区二区三区四区| 日韩欧美中文视频| 亚洲免费在线看| 99国产精品一区二区三区| 久久精品国产2020观看福利| 亚洲国产91视频| 色撸撸在线观看| 韩国视频一区二区| 国产一二三四区| 51精品久久久久久久蜜臀| 好吊日视频在线观看| 91中文在线视频| 好吊日精品视频| 在线观看av中文字幕| 欧美日韩在线影院| 黄色国产在线| 国产精品偷伦一区二区| 91综合视频| 日本一本在线视频| 亚洲成av人影院| 男女污污视频在线观看| 国产精品久久久久7777婷婷| 成人影视亚洲图片在线| 国产精品嫩草影院8vv8| 亚洲综合一区二区三区| 天天干天天操av| 57pao精品| 欧美日韩国产免费观看视频| 午夜视频你懂的| 综合电影一区二区三区| 精品国产乱码一区二区三| 97在线视频免费观看| 牲欧美videos精品| 精品免费国产一区二区| 国产精品女人毛片| 色播视频在线播放| 久久久久久久久久久妇女 | 韩日午夜在线资源一区二区| 殴美一级特黄aaaaaa| 91亚洲精品久久久蜜桃| 亚洲国产精品毛片| 中文字幕资源网在线观看| 天涯成人国产亚洲精品一区av| 精品久久久久av| 精品国产亚洲一区二区在线观看 | 裸体武打性艳史| 国产欧美精品国产国产专区| 国产精品国产精品国产| 久久综合久久88| 精品欠久久久中文字幕加勒比| 国产一区亚洲二区三区| 最近中文字幕一区二区三区| 免费av网站观看| 国产精品爽黄69| 一区免费在线| 999福利视频| 亚洲国产精品女人久久久 | 国产日韩精品在线观看| 国产精品地址| 成人小视频免费看|