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

如何優(yōu)化前端性能?

開發(fā) 開發(fā)工具
本文基于Quick BI(數(shù)據(jù)可視化分析平臺(tái))歷年架構(gòu)變遷中性能的排查、解決和總結(jié)出的“個(gè)性”問題,嘗試總結(jié)整個(gè)前端層面相對(duì)“共性”的問題,提供一些前端性能解決思路。

一 引發(fā)性能問題原因?

引發(fā)性能問題的原因通常不是單方面緣由,特別是大型系統(tǒng)迭代多年后,長期積勞成疾造成,所以我們要必要分析找到癥結(jié)所在,并按瓶頸優(yōu)先級(jí)逐個(gè)擊破,拿我們項(xiàng)目為例,大概分幾個(gè)方面:

1 資源包過大

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

??

??

 

經(jīng)過前端高速發(fā)展,近幾年項(xiàng)目更新迭代,前端構(gòu)建產(chǎn)物也在急劇增大,因?yàn)橐獦I(yè)務(wù)先行,很多同學(xué)引入庫和編碼過程并沒有考慮性能問題,導(dǎo)致構(gòu)建的包增至幾十MB,這樣帶來兩個(gè)顯著的問題:

  • 弱(普通)網(wǎng)絡(luò)下,首屏資源下載耗時(shí)長
  • 資源解壓解析執(zhí)行慢

對(duì)于第一個(gè)問題,基本上會(huì)影響所有移動(dòng)端用戶,并且會(huì)耗費(fèi)大量不必要的用戶帶寬,對(duì)客戶是一個(gè)經(jīng)濟(jì)上的隱式損失和體驗(yàn)損失。

對(duì)于第二個(gè)問題,會(huì)影響所有用戶,用戶可能因?yàn)榈却龝r(shí)間過長而放棄使用。

下圖展示了延遲與用戶反應(yīng):

??

??

 

2 代碼耗時(shí)長

在代碼執(zhí)行層面,項(xiàng)目迭代中引發(fā)的性能問題普遍是因?yàn)殚_發(fā)人員編碼質(zhì)量導(dǎo)致,大概以下幾個(gè)緣由:

不必要的數(shù)據(jù)流監(jiān)聽

此場景在hooks+redux的場景下會(huì)更容易出現(xiàn),如下代碼:

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

假設(shè)fullData是頻繁變更的大對(duì)象,雖然FooComponent僅依賴其.bar.baz屬性,fullData每次變更也會(huì)導(dǎo)致Foo重新渲染。

雙刃劍cloneDeep

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

// a.tsx 
export const a = {
name: 'a',
};
// b.tsx
import { a } = b;
saveData(_.cloneDeep(a)); // 假設(shè)需要克隆后落庫到后端數(shù)據(jù)庫

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

Hooks之Memo

hooks的發(fā)布,給react開發(fā)帶來了更高的自由度,同時(shí)也帶來了容易忽略的質(zhì)量問題,由于不再有類中明碼標(biāo)價(jià)的生命周期概念,組件狀態(tài)需要開發(fā)人員自由控制,所以開發(fā)過程中務(wù)必懂得react對(duì)hooks組件的渲染機(jī)制,如下代碼可優(yōu)化的地方:

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

Immutable Deep Set

在使用數(shù)據(jù)流的過程中,很大程度我們會(huì)依賴lodash/fp的函數(shù)來實(shí)現(xiàn)immutable變更,但fp.defaultsDeep系列函數(shù)有個(gè)弊端,其實(shí)現(xiàn)邏輯相當(dāng)于對(duì)原對(duì)象作深度克隆后執(zhí)行fp.set,可能帶來一些性能問題,并且導(dǎo)致原對(duì)象所有層級(jí)屬性都被變更,如下:

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

3 排查路徑

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

??

??

 

當(dāng)我們鎖定一個(gè)耗時(shí)較長的環(huán)節(jié),就可以再通過矩陣樹圖往下深入(下圖),找到具體耗時(shí)較長的函數(shù)。

??

??

 

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

??

??

 

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

二 如何解決性能問題?

1 資源包分析

作為一名有性能sense的開發(fā)者,有必要對(duì)自己構(gòu)建的產(chǎn)物內(nèi)容保持敏感,這里我們使用到webpack提供的stats來作產(chǎn)物分析。

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

??

??

 

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

??

??

 

紅色表示未執(zhí)行過的代碼

最佳構(gòu)建方式

通常來講,我們組織構(gòu)建包的基本思路是:

  • 按entry入口構(gòu)建。
  • 一個(gè)或多個(gè)共享包供多entry使用。

而基于復(fù)雜業(yè)務(wù)場景的思路是:

  • entry入口輕量化。
  • 共享代碼以chunk方式自動(dòng)生成,并建立依賴關(guān)系。
  • 大資源包動(dòng)態(tài)導(dǎo)入(異步import)。

webpack 4中提供了新的插件 splitChunks 來解決代碼分離優(yōu)化的問題,它的默認(rèn)配置如下:

module.exports = { 
//...
optimization: {
splitChunks: {
chunks: 'async',
minSize: 20000,
minRemainingSize: 0,
maxSize: 0,
minChunks: 1,
maxAsyncRequests: 30,
maxInitialRequests: 30,
automaticNameDelimiter: '~',
enforceSizeThreshold: 50000,
cacheGroups: {
defaultVendors: {
test: /[\\/]node_modules[\\/]/,
priority: -10
},
default: {
minChunks: 2,
priority: -20,
reuseExistingChunk: true
}
}
}
}
};

根據(jù)上述配置,其分離chunk的依據(jù)有以下幾點(diǎn):

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

理論上webpack默認(rèn)的代碼分離配置已經(jīng)是最佳方式,但如果項(xiàng)目復(fù)雜或耦合程度較深,仍然需要我們根據(jù)實(shí)際構(gòu)建產(chǎn)物大圖情況,調(diào)整我們的chunk split配置。

解決TreeShaking失效

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

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

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

??

??

 

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

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

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

模塊規(guī)范

由此,要使得構(gòu)建產(chǎn)物達(dá)到最佳效果,我們?cè)诰幋a過程中約定了以下幾點(diǎn)模塊規(guī)范:

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

2 Mutable數(shù)據(jù)

基本上通過Performance和React插件提供的調(diào)試能力,我們基本可以定位問題所在。但對(duì)于mutable型的數(shù)據(jù)變更,我這里也結(jié)合實(shí)踐給出一些非標(biāo)準(zhǔn)調(diào)試方式:

凍結(jié)定位法

眾所周知,數(shù)據(jù)流思想的產(chǎn)生緣由之一就是避免mutable數(shù)據(jù)無法追溯的問題(因?yàn)槟銦o法知道是哪段代碼改了數(shù)據(jù)),而很多項(xiàng)目中避免不了mutable數(shù)據(jù)更改,此方法就是為了解決一個(gè)棘手的mutable數(shù)據(jù)變更問題而想出的方法,這里我暫時(shí)命名為“凍結(jié)定位法”,因?yàn)樵砭褪鞘褂脙鼋Y(jié)方式定位mutable變更問題,使用相當(dāng)tricky:

constob j= { 
prop: 42
};

Object.freeze(obj);

obj.prop=33; // Throws an error in strict mode

Mutable追溯

此方法也是為了解決mutable變更引發(fā)數(shù)據(jù)不確定性變更問題,用于實(shí)現(xiàn)排查的幾個(gè)目的:

  • 屬性在什么地方被讀取。
  • 屬性在什么地方被變更。
  • 屬性對(duì)應(yīng)的訪問鏈路是什么。

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

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

watchObject 的原理即對(duì)一個(gè)對(duì)象進(jìn)行深度 Proxy 封裝,從而攔截get/set權(quán)限,詳細(xì)可參考: https://gist.github.com/wilsoncook/68d0b540a0fea24495d83fc284da9f4b

避免Mutable

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

3 計(jì)算&渲染

最小化數(shù)據(jù)依賴

在項(xiàng)目組件爆炸式增長的情況下,數(shù)據(jù)流store內(nèi)容層級(jí)也逐漸變深,很多組件依賴某個(gè)屬性觸發(fā)渲染,這個(gè)依賴項(xiàng)需要盡可能在設(shè)計(jì)時(shí)遵循最小化原則,避免像上方所述,依賴一個(gè)大的屬性導(dǎo)致頻繁渲染。

合理利用緩存

(1)計(jì)算結(jié)果

在一些必要的cpu密集型計(jì)算邏輯中,務(wù)必采用 WeakMap 等緩存機(jī)制,存儲(chǔ)當(dāng)前計(jì)算終態(tài)結(jié)果或中間狀態(tài)。

(2)組件狀態(tài)

對(duì)于像hooks型組件,有必要遵循以下兩個(gè)原則:

  • 盡可能memo耗時(shí)邏輯。
  • 無多余memo依賴項(xiàng)。

避免cpu密集型函數(shù)

某些工具類函數(shù),其復(fù)雜度跟隨入?yún)⒌牧考?jí)上升,而另外一些本身就會(huì)耗費(fèi)大量cpu時(shí)間。針對(duì)這類型的工具,要盡量避免使用,若無法避免,也可通過 “控制入?yún)?nèi)容(白名單)” 及 “異步線程(webworker等)”方式做到嚴(yán)控。

比如針對(duì) _.cloneDeep ,若無法避免,則要控制其入?yún)傩灾胁坏糜幸弥惖拇笮蛿?shù)據(jù)。

另外像最上面描述的immutable數(shù)據(jù)深度merge的問題,也應(yīng)該盡可能控制入?yún)ⅲ蛘咭部蓞⒖际褂米匝械膇mmutable實(shí)現(xiàn):https://gist.github.com/wilsoncook/fcc830e5fa87afbf876696bf7a7f6bb1

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

三 寫在最后

以上,總結(jié)了Quick BI性能優(yōu)化過程中的部分心得和經(jīng)驗(yàn),性能是每個(gè)開發(fā)者不可繞過的話題,我們的每段代碼,都對(duì)標(biāo)著產(chǎn)品的健康度。

【本文為51CTO專欄作者“阿里巴巴官方技術(shù)”原創(chuàng)稿件,轉(zhuǎn)載請(qǐng)聯(lián)系原作者】

 

??戳這里,看該作者更多好文??

 

責(zé)任編輯:武曉燕 來源: 51CTO專欄
相關(guān)推薦

2020-10-16 09:00:12

前端開發(fā)技術(shù)

2019-11-01 14:00:58

前端性能優(yōu)化代碼

2022-11-16 12:03:13

性能優(yōu)化前端

2022-05-17 09:02:30

前端性能優(yōu)化

2021-05-31 08:30:50

監(jiān)控網(wǎng)站性能

2021-07-05 14:55:28

前端優(yōu)化圖片

2022-03-02 11:13:50

Web前端開發(fā)

2023-04-10 11:18:38

前端性能優(yōu)化

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

前端性能優(yōu)化編程

2023-10-18 10:38:53

API

2022-09-13 12:56:28

前端優(yōu)化

2020-08-24 07:12:17

前端CRP性能優(yōu)化

2023-12-14 17:21:28

前端性能優(yōu)化

2020-03-31 14:16:25

前端性能優(yōu)化HTTP

2019-07-29 10:39:39

前端性能優(yōu)化緩存

2017-02-05 17:33:59

前端優(yōu)化Web性能
點(diǎn)贊
收藏

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

在线播放国产一区中文字幕剧情欧美| 五月天亚洲婷婷| caoporn国产精品免费公开| 欧美精品成人久久| 伦理一区二区| 欧美日韩精品一区二区三区蜜桃 | 日韩欧美一区二区三区免费看| 欧美美女黄视频| 久艹在线免费观看| bbbbbbbbbbb在线视频| 国产高清视频一区| 国产不卡视频在线| 欧美精品成人久久| 成人激情诱惑| 亚洲国产精品va在线看黑人动漫| av网站在线不卡| 超碰在线cao| 亚洲同性同志一二三专区| 国产欧美日韩一区| 97超碰人人草| 久久中文在线| 欧美精品久久久久久久久| 激情高潮到大叫狂喷水| 女优一区二区三区| 亚洲第一网中文字幕| 亚洲精品国产一区二区三区| 北岛玲heyzo一区二区| 亚洲自拍偷拍图区| 在线无限看免费粉色视频| 四虎影视2018在线播放alocalhost| 国内精品视频666| 国产精品爱久久久久久久| 欧美三级午夜理伦| 欧美三级不卡| 欧美日韩国产成人在线观看| 精品亚洲乱码一区二区| 精品国内自产拍在线观看视频 | 欧美挠脚心视频网站| 大香煮伊手机一区| 女人高潮被爽到呻吟在线观看| 亚洲激情图片一区| 中文字幕在线中文字幕日亚韩一区| 黄色片在线免费看| 91麻豆精东视频| 九色视频成人porny| 高h放荡受浪受bl| 国产成人免费av在线| 亚洲最大av在线| 国产区精品在线| 精品中文字幕一区二区| 91精品久久久久久久| 中文字幕一区二区人妻痴汉电车| 久久一区视频| 国产精品wwwwww| 精品国产www| 麻豆精品一区二区| 91精品美女在线| 国产伦精品一区二区三区四区| 老司机免费视频一区二区三区| 国产精品免费在线免费 | 视频在线观看一区| 国产精品久久久久久久久久小说| 69av视频在线观看| 欧美aaa在线| 成人黄色激情网| 国产视频www| 成人免费毛片片v| 国产在线精品二区| 四虎影院在线播放| 国产精品麻豆久久久| 国产又粗又大又爽的视频| 免费在线观看av电影| 天天综合色天天综合| 乱子伦视频在线看| 91国产一区| 欧美成人猛片aaaaaaa| 亚洲日本久久久| 久久99蜜桃| 久久亚洲综合国产精品99麻豆精品福利 | 欧美v在线观看| 成人激情视屏| 精品人伦一区二区色婷婷| 荫蒂被男人添免费视频| 国产亚洲电影| 欧美成人合集magnet| 97人人澡人人爽人人模亚洲 | 亚洲自拍偷拍欧美| 999香蕉视频| 国产精品视频一区二区三区综合| 亚洲成av人影院在线观看| 高潮毛片无遮挡| 99久久夜色精品国产亚洲96 | 电影一区二区| 日韩一级完整毛片| 最近中文字幕免费视频| 亚洲欧洲美洲一区二区三区| 欧美在线xxx| 国产日本精品视频| 国产三级久久久| 国产又粗又猛又爽又黄的网站| 永久免费毛片在线播放| 777久久久精品| www.色多多| 亚洲深深色噜噜狠狠爱网站| 日韩**中文字幕毛片| 国产suv精品一区二区69| xfplay精品久久| a级片一区二区| av在线日韩| 亚洲国产美女久久久久| 欧美大片xxxx| 蜜桃视频在线一区| 久久国产精品 国产精品| 最新日本在线观看| 欧美日韩免费观看一区三区| 极品粉嫩小仙女高潮喷水久久| 亚洲色图网站| 国产精品一二三在线| 瑟瑟在线观看| 亚洲成人午夜影院| 在线成人免费av| 日韩一区电影| 日本国产高清不卡| 天堂av资源网| 亚洲午夜免费福利视频| 99精品999| 日韩在线第七页| 国产精品九九九| 狠狠v欧美ⅴ日韩v亚洲v大胸| 亚洲午夜一区二区| 久久人妻少妇嫩草av蜜桃| 99精品综合| 国产日韩换脸av一区在线观看| 久久综合九色综合久| 精品久久久久久久中文字幕| 欧美夫妇交换xxx| 最新成人av网站| 国产欧美亚洲日本| 大香伊人久久| 精品国产三级a在线观看| 免费一级a毛片夜夜看| 国产精品羞羞答答xxdd| 二级片在线观看| 成年永久一区二区三区免费视频| 爽爽爽爽爽爽爽成人免费观看| 激情网站在线观看| 亚洲国产精品av| 中文久久久久久| 日本欧美视频| 国产一区玩具在线观看| 快射av在线播放一区| 91精品国产色综合久久不卡蜜臀 | 日韩欧美视频| 成人一区二区电影| 99视频免费在线观看| 欧美xxxxxxxx| 日韩av在线播| 久久蜜桃av一区精品变态类天堂 | 国产视频精品久久久| 毛片视频网站在线观看| 久久综合九色综合久久久精品综合| 男人天堂999| 成人激情电影在线| 亚洲伊人第一页| 久草免费在线色站| 亚洲精品一二区| 一级成人免费视频| 亚洲综合一区在线| aaaaa级少妇高潮大片免费看| 日韩精品一级二级 | 久久中文欧美| 伊人久久大香线蕉av一区| 精品视频在线观看网站| 久久久久久久久久久久久久久久久久av | av成人在线观看| 久久国产色av| 无码精品在线观看| 精品婷婷伊人一区三区三| 国产又黄又爽又无遮挡| 99精品视频一区| 久久久国产欧美| 欧美日韩四区| 欧美一区二区三区四区夜夜大片 | 久草手机在线观看| 欧美国产禁国产网站cc| 中国老熟女重囗味hdxx| 在线视频免费在线观看一区二区| 亚洲黄色成人久久久| 久久久国产精品入口麻豆| 98精品国产自产在线观看| aaa日本高清在线播放免费观看| 欧美一区二区福利视频| 久久久久99精品成人片我成大片| 国产精品乱人伦一区二区| 无码av免费精品一区二区三区| 日产欧产美韩系列久久99| 无码日本精品xxxxxxxxx| 黑人操亚洲人| 国产精华一区| 亚洲伦理久久| 日韩免费在线播放| 日韩精品卡一| 日韩一区二区三区xxxx| 涩爱av在线播放一区二区| 日韩亚洲欧美高清| 中文字幕 亚洲视频| 亚洲成av人片一区二区| 日韩在线中文字幕视频| 国产日韩欧美在线一区| 在线看黄色的网站| 国产美女主播视频一区| 欧美黑人又粗又大又爽免费| 欧美精品一卡| 女人床在线观看| 91亚洲一区| 日韩欧美视频一区二区| 欧美精品国产白浆久久久久| 99国产高清| 一级欧美视频| 国产精品亚洲自拍| 免费观看成人性生生活片| 午夜精品久久久久久久白皮肤| 2024最新电影在线免费观看| 日韩资源在线观看| www.亚洲视频| 伊人久久综合97精品| 欧美香蕉爽爽人人爽| 日韩av影视在线| 日韩在线视频第一页| 精品少妇一区二区三区在线播放 | 国产精品久久久免费视频| 一区二区三区日韩欧美精品 | 77777影视视频在线观看| 亚洲天堂av综合网| 日本v片在线免费观看| 亚洲国产私拍精品国模在线观看| 亚洲av色香蕉一区二区三区| 欧美一区二区在线看| 国产精品久久欧美久久一区| 欧美日本国产一区| 一二三区在线播放| 欧美巨大另类极品videosbest | 成人黄色大片在线观看| 国产精品二区视频| 国产成人精品影院| 俄罗斯黄色录像| caoporm超碰国产精品| 私密视频在线观看| 久久久精品黄色| 久久久久久久久福利| 国产精品视频你懂的| 国产人与禽zoz0性伦| 亚洲激情综合网| 久久久精品视频免费| 午夜精品一区二区三区免费视频| 欧美亚韩一区二区三区| 色综合天天综合| 影音先锋国产资源| 91精品国产手机| 欧美一级性视频| 精品亚洲一区二区三区四区五区 | 免费91麻豆精品国产自产在线观看| 久操视频在线免费播放| 欧美国产日韩一区二区三区| 成人女同在线观看| 欧美有码在线视频| jizz久久久久久| 91福利视频导航| 老牛影视av一区二区在线观看| 久久亚洲精品欧美| 日韩欧美高清| 丁香六月激情婷婷| 久久狠狠婷婷| 久久久久久综合网| aaa国产一区| 91香蕉国产视频| 夜夜嗨av一区二区三区网页| 好吊妞视频一区二区三区| 欧美在线观看视频在线| av高清一区二区| 精品亚洲国产视频| а√天堂8资源在线官网| 97视频在线观看播放| 成人午夜在线| 国产一区二区三区高清| 久久精品国产68国产精品亚洲| 国产内射老熟女aaaa| 老妇喷水一区二区三区| 波多野结衣免费观看| 26uuu国产在线精品一区二区| 男人的午夜天堂| 欧美小视频在线| 国产喷水吹潮视频www| 亚洲天堂日韩电影| 免费污视频在线| 成人黄色av网站| 综合国产视频| 又大又硬又爽免费视频| 捆绑紧缚一区二区三区视频 | 天堂俺去俺来也www久久婷婷 | 一本色道88久久加勒比精品| 在线观看国产一级片| 99视频超级精品| 加勒比婷婷色综合久久| 欧美视频在线不卡| 艳母动漫在线看| 欧美精品一区在线播放| 国产成人a视频高清在线观看| 国内精品二区| 欧美成人一品| 99热一区二区| 国产片一区二区三区| 精品少妇theporn| 欧美另类变人与禽xxxxx| 亚洲三级黄色片| 久久久久久久电影一区| www.成人在线.com| 一区二区精品在线| 青青草精品视频| 亚洲AV无码片久久精品| 黑人巨大精品欧美一区二区一视频| 精品国产av鲁一鲁一区| 精品国产一区久久久| 91亚洲视频| 日韩免费中文专区| 日韩主播视频在线| 熟女俱乐部一区二区| 亚洲成人tv网| 欧美77777| 欧美激情极品视频| 亚洲性视频在线| japanese在线播放| 国产91对白在线观看九色| 久草免费新视频| 欧美成人a视频| 日本精品600av| 成人在线视频电影| 亚洲成色精品| 国产 中文 字幕 日韩 在线| 亚洲aaa精品| 熟妇人妻中文av无码| 欧美性在线观看| 丝袜久久网站| 青青在线免费观看视频| 久久久久久久免费视频了| 无码人妻av免费一区二区三区| 精品视频在线播放免| 唐人社导航福利精品| 神马影院午夜我不卡| 免费看精品久久片| 成人免费毛片xxx| 精品国产自在久精品国产| 菠萝蜜视频在线观看www入口| 国产一级特黄a大片99| 久久精品官网| 真实乱视频国产免费观看| 欧美色电影在线| caoporn免费在线视频| 成人动漫视频在线观看完整版 | 91黑丝高跟在线| 亚洲亚洲免费| 欧美美女性视频| 亚洲自拍与偷拍| 毛片在线播放网址| 国产日韩精品视频| 国产一区欧美| 欧美大片免费播放器| 欧美影片第一页| 91在线中字| 麻豆传媒一区| 精品无人区卡一卡二卡三乱码免费卡| 欧美片一区二区| 国产丝袜一区视频在线观看| 欧美日韩国产网站| 青青草综合在线| 国产性做久久久久久| 99久久精品国产一区二区成人| 久久久久久久久久久久av| 国产一区不卡| 波多野结衣电影免费观看| 欧美丝袜美女中出在线| 国产乱色在线观看| 久久综合久久久| 黄网站免费久久| 国产高清中文字幕| 久久国产精品久久久久久久久久| 美女午夜精品| 17c国产在线| 欧美性生交大片免费| 老司机在线永久免费观看| 精品欧美国产| 国内不卡的二区三区中文字幕| 国产精品国产三级国产专区52| 久久精品91久久久久久再现| 日韩精品免费一区二区夜夜嗨 | 中文字幕免费播放| 7m精品福利视频导航| 久久精品青草| 久久久久久久久久久久久久久| 日韩欧美国产一区在线观看|