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

圖解Webpack之優(yōu)化篇

開(kāi)發(fā) 架構(gòu)
首先用一張利用MindMaster繪制思維導(dǎo)圖開(kāi)篇來(lái)闡述本文的主要內(nèi)容,讀者可在此基礎(chǔ)上進(jìn)行擴(kuò)展自己的思維導(dǎo)圖。webpack除了基礎(chǔ)的配置外,還需要進(jìn)行優(yōu)化。

[[421852]]

首先用一張利用MindMaster繪制思維導(dǎo)圖開(kāi)篇來(lái)闡述本文的主要內(nèi)容,讀者可在此基礎(chǔ)上進(jìn)行擴(kuò)展自己的思維導(dǎo)圖。webpack除了基礎(chǔ)的配置外,還需要進(jìn)行優(yōu)化。對(duì)于開(kāi)發(fā)環(huán)境主要優(yōu)化打包構(gòu)建速度和代碼調(diào)試;對(duì)于生產(chǎn)環(huán)境主要優(yōu)化打包的構(gòu)建速度和代碼運(yùn)行的性能。

一、開(kāi)發(fā)環(huán)境

1.1 構(gòu)建速度

在開(kāi)發(fā)環(huán)境中為了提升代碼構(gòu)建速度,可以利用HMR(模塊熱替換)來(lái)實(shí)現(xiàn),通過(guò)該功能可以允許只變更更新內(nèi)容,而不需將所有內(nèi)容進(jìn)行構(gòu)建,極大提升構(gòu)建速度。

1. 開(kāi)啟

  1. module.exports = { 
  2.     // ... 
  3.     devServer: { 
  4.         hot: true
  5.     } 

2.樣式文件

對(duì)于樣式文件,借助于style-loader即可實(shí)現(xiàn)模塊熱替換,這是因?yàn)榇薼oader使用了module.hot.accept,在樣式改變后就可以熱更新到style標(biāo)簽中。

3.js文件

對(duì)于js文件默認(rèn)不能使用HMR功能,為了讓js文件支持該功能,可以借助于module.hot.accept這個(gè)接口,當(dāng)監(jiān)聽(tīng)的模塊更新后,觸發(fā)一個(gè)回調(diào)函數(shù)對(duì)更新做出響應(yīng)。(注意:只能處理非入口js文件,因?yàn)槿肟趈s文件會(huì)引入其它文件,重新引入導(dǎo)致重新加載)。

  1. // 判斷是否啟動(dòng)熱更新 
  2. if (module.hot) { 
  3.   module.hot.accept('./js/add.js', () => { 
  4.     console.log(add(1, 2)); 
  5.   }); 

1.2 代碼調(diào)試

1.2.1 devServer

devServer主要目的是實(shí)現(xiàn)自動(dòng)化(自動(dòng)編譯、自動(dòng)打開(kāi)瀏覽器、自動(dòng)刷新瀏覽器……)。為了實(shí)現(xiàn)該功能,可以借助webpack-dev-server,通過(guò)其可以構(gòu)建一個(gè)小型的Web服務(wù)器,能夠?qū)崟r(shí)重新加載。(注意:利用webpack-dev-server啟動(dòng)的項(xiàng)目只會(huì)在內(nèi)存中編譯打包,不會(huì)有任何輸出,這是因?yàn)樵L問(wèn)內(nèi)存中的代碼比訪問(wèn)文件系統(tǒng)化中的文件更快)

  1. module.exports = { 
  2.     // ... 
  3.     devServer: { 
  4.         // 啟動(dòng)gzip壓縮 
  5.         compress: true
  6.         port: 3000, 
  7.         opentrue
  8.     } 

1.2.2 source map

利用source map可以將編譯后的代碼映射回原始源代碼,從而更容易地追蹤error和warning。對(duì)于如何生成source map,利用devtool選項(xiàng),其選項(xiàng)值可以是:[inline-|hidden-|eval-][nosources-][cheap-[module-]]source-map,每個(gè)值具體含義可參照官網(wǎng)。

開(kāi)發(fā)環(huán)境要求構(gòu)建速度快、調(diào)試更友好。構(gòu)建速度快,肯定采用內(nèi)聯(lián)方式(eval和inline);為了使調(diào)試更友好,則需要定位到代碼位置,可以使用source-map、cheap-module-source-map、cheap-source-map。綜上所述可以使用eval-source-map 或 eval-cheap-module-source-map。

因?yàn)閮?nèi)聯(lián)方式會(huì)讓代碼體積變大,所以在生產(chǎn)環(huán)境下不用內(nèi)聯(lián)方式。在生產(chǎn)環(huán)境條件下,需要考慮兩點(diǎn):源代碼是否需要隱藏、調(diào)試如何更友好。若隱藏代碼可以使用nosource-source-map和hidden-source-map;為了調(diào)試更友好,可采用source-map和cheap-module-source-map。

  1. module.exports = { 
  2.     // ... 
  3.     devtool: 'eval-source-map' 

二、生產(chǎn)環(huán)境

2.1 打包構(gòu)建速度

2.1.1 oneOf

每個(gè)文件對(duì)于rules中的所有規(guī)則都會(huì)遍歷一遍,如果使用oneOf就可以解決該問(wèn)題,只要能匹配一個(gè)即可退出。(注意:在oneOf中不能兩個(gè)配置處理同一種類型文件)

  1. module.exports = { 
  2.     // ... 
  3.     module: { 
  4.         rules: [ 
  5.             { 
  6.                 oneOf: [ 
  7.                     // ... 
  8.                 ] 
  9.             } 
  10.         ] 
  11.     } 

2.1.2 babel緩存

Babel在轉(zhuǎn)義js文件過(guò)程中消耗性能較高,將babel-loader執(zhí)行的結(jié)果緩存起來(lái),當(dāng)重新打包構(gòu)建時(shí)會(huì)嘗試讀取緩存,從而提高打包構(gòu)建速度、降低消耗。

  1. module.exports = { 
  2.     // ... 
  3.     module: { 
  4.         rules: [ 
  5.             { 
  6.                 test: /\.js$/, 
  7.                 exclude: /node_modules/, 
  8.                 loader: 'babel-loader'
  9.                 options: { 
  10.                     // ... 
  11.                     // 開(kāi)啟babel緩存。第二次構(gòu)建時(shí),會(huì)讀取之前的緩存 
  12.                     cacheDirectory: true 
  13.                 } 
  14.             } 
  15.         ] 
  16.     } 

2.1.3 多進(jìn)程打包

webpack構(gòu)建過(guò)程中需要大量文件進(jìn)行解析和處理,所以構(gòu)建時(shí)文件讀寫(xiě)和計(jì)算密集型的操作,而運(yùn)行在Node.js之上的Webpack是單線程模型,所以構(gòu)建起來(lái)速度會(huì)比較慢,此時(shí)為了提升構(gòu)建速度,可以選擇發(fā)揮多核CPU電腦的功能,利用多進(jìn)程來(lái)提升構(gòu)建速度。可以利用thread-loader來(lái)進(jìn)行多進(jìn)程打包,將該loader放置在其他loader之前, 放置在這個(gè) loader 之后的 loader 就會(huì)在一個(gè)單獨(dú)的 worker 池(worker pool)中運(yùn)行(注意:每個(gè) worker 都是一個(gè)單獨(dú)的有 600ms 限制的 node.js 進(jìn)程,只有工作消耗時(shí)間比較長(zhǎng)才需要多進(jìn)程打包)。

  1. module.exports = { 
  2.     // ... 
  3.     module: { 
  4.         rules: [ 
  5.             { 
  6.                 // ... 
  7.                 use: [ 
  8.                     { 
  9.                         loader: 'thread-loader'
  10.                         options: { 
  11.                             workers: 2 //兩個(gè)進(jìn)程 
  12.                         } 
  13.                     }, 
  14.                     // ... 
  15.                 ] 
  16.             } 
  17.         ] 
  18.     } 

2.1.4 externals

externals告訴在Webpack要構(gòu)建的代碼中使用了哪些不用被打包的模塊,也就是說(shuō)在運(yùn)行時(shí)再去從外部獲取這些擴(kuò)展依賴,這樣就會(huì)減少打包的內(nèi)容,從而減少打包時(shí)間并減小包的體積。例如直接通過(guò)script標(biāo)簽從CDN中引入jQuery,而不是將它打包。

  1. module.exports = { 
  2.     externals: { 
  3.         // 拒絕jQuery被打包進(jìn)來(lái) 
  4.         jquery: 'jQuery' 
  5.     } 

2.1.5 DLL

DLL即動(dòng)態(tài)鏈接庫(kù),使用該技術(shù)能夠?qū)δ承?kù)(react、vue、jquery……)進(jìn)行單獨(dú)打包,通過(guò)單獨(dú)打包后,后續(xù)可直接引用,不需要再次進(jìn)行打包(只需要打包一次),極大提升構(gòu)建速度。在這個(gè)過(guò)程中主要涉及到三個(gè)步驟:

1.新建webpack.dll.js文件,用來(lái)進(jìn)行單獨(dú)打包生成動(dòng)態(tài)鏈接庫(kù)文件和mainfest.json,這樣在以后構(gòu)建的時(shí)候就不用重復(fù)打包了,可直接引用。(該文件中用到DllPlugin插件,用于生成mainfest.json文件,提供一個(gè)映射關(guān)系)

  1. const path = require('path'); 
  2. const webpack = require('webpack'); 
  3.  
  4. module.exports = { 
  5.     entry: { 
  6.         jquery: ['jquery'
  7.     }, 
  8.     output: { 
  9.         filename: '[name].js'
  10.         path: path.resolve(__dirname, 'dll'), 
  11.         library: '[name]_[hash]'// 打包的庫(kù)里面向外暴露出去的內(nèi)容叫什么名字 
  12.     }, 
  13.     plugins: [ 
  14.         // 打包生成一個(gè)mainfest.json,從而提供和對(duì)應(yīng)包的映射 
  15.         new webpack.DllPlugin({ 
  16.             name'[name]_[hash]',// 映射庫(kù)的暴露的內(nèi)容名稱 
  17.             path: path.resolve(__dirname, 'dll/mainfest.json'),// 輸出文件路徑 
  18.         }) 
  19.     ], 
  20.     mode: 'production' 
  21. }; 

2.在webpack.config.js文件中配置webpack.DllReferencePlugin,從而在主文件中引入打包好的動(dòng)態(tài)鏈接庫(kù)文件,從而讓主文件知道哪些文件不需要打包,打包庫(kù)里的名字是什么……

  1. module.exports = { 
  2.     // ... 
  3.     plugins: [ 
  4.         new webpack.DllReferencePlugin({ 
  5.             manifest: resolve(__dirname, 'dll/mainfest.json'
  6.         }), 
  7.     ] 

3.由于動(dòng)態(tài)鏈接庫(kù)文件并沒(méi)有被引入進(jìn)html文件中,利用add-asset-html-webpack-plugin插件即可將該鏈接庫(kù)文件在html中自動(dòng)引入。

  1. module.exports = { 
  2.     // ... 
  3.     plugins: [ 
  4.         new AddAssetHtmlWebpackPlugin({ 
  5.             filepath: resolve(__dirname, 'dll/jquery.js'
  6.         }) 
  7.     ] 

2.2 代碼運(yùn)行性能

2.2.1 緩存

獲取資源是比較耗費(fèi)時(shí)間的,利用緩存可以降低網(wǎng)絡(luò)流量,使網(wǎng)站加載速度更快。由于強(qiáng)緩存會(huì)存在內(nèi)容不能及時(shí)更新的問(wèn)題,為了解決該問(wèn)題,則需要為webpack配置的文件名加上hash值。對(duì)于webpack中hash值主要有三種:hash、chunkhash、contenthash。由于緩存希望一個(gè)文件改動(dòng)只會(huì)影響該文件的緩存,其余文件緩存不失效,所以該hash值應(yīng)該選擇根據(jù)文件內(nèi)容生成的hash值contenthash,即文件命名中添加contenthash。

hash值類型 特點(diǎn)
hash 每次webpack構(gòu)建時(shí)生成一個(gè)唯一的hash值
chunkhash 根據(jù)chunk生成hash值,來(lái)源于同一個(gè)chunk,則hash值就一樣
contenthash 根據(jù)內(nèi)容生成hash值,文件內(nèi)容相同hash值就相同
 

2.2.2 tree shaking

通常用于描述移除 JavaScript上下文中的未引用代碼(dead-code),讓代碼體積變的更小。為了實(shí)現(xiàn)該功能,需要兩個(gè)前提條件:一是必須使用ES6模塊,二是開(kāi)啟production環(huán)境。(注意:為了放置將可能有副作用的文件(例如:css文件)刪除掉,則需要將其添加到package.json文件中的sideEffects的配置中(例如:"sideEffects":["*.css"]))。

2.2.3 代碼分割

代碼分割就是把打包輸出的代碼分離到不同的bundle中,然后可以按需加載或并行加載這些文件。常用的方法主要有三種:入口起點(diǎn)、防止重復(fù)、動(dòng)態(tài)導(dǎo)入。

1.入口起點(diǎn)

利用單入口和多入口(對(duì)象形式)的方式進(jìn)行拆分,有一個(gè)入口就會(huì)輸出一個(gè)bundle。對(duì)于這種方式存在重復(fù)引用的弊端,為了解決該問(wèn)題需要利用SplitChunksPlugin插件,即下面的防止重復(fù)的方法。

2.防止重復(fù)

利用SplitChunksPlugin可以進(jìn)行公共代碼提取,提取主要包括兩類:一類是可以將來(lái)自node_modules文件夾下的模塊單獨(dú)打包為一個(gè)chunk輸出;另一類是對(duì)于多入口,會(huì)自動(dòng)分析多入口chunk中公共文件(該文件大于30kb才會(huì)單獨(dú)打包)并單獨(dú)打包為一個(gè)chunk。

  1. module.exports = { 
  2.     // ... 
  3.     optimization: { 
  4.         splitChunks: { 
  5.             chunks: 'all' 
  6.         } 
  7.     } 

3.動(dòng)態(tài)導(dǎo)入

利用import()語(yǔ)法能夠?qū)崿F(xiàn)動(dòng)態(tài)導(dǎo)入,從而將某個(gè)文件單獨(dú)打包。

  1. import(/* webpackChunkName: 'add' */'./js/add'
  2.     .then(({ add }) => { 
  3.         console.log(add(1, 2)); 
  4.     }) 
  5.     .catch(() => {}) 

2.2.4 懶加載

懶加載是一種很好的優(yōu)化方式,當(dāng)代碼被需要時(shí)才會(huì)進(jìn)行下載,這樣就加快了應(yīng)用的初始加載速度并減輕了代碼的總體體積(因?yàn)橛行┐a永遠(yuǎn)不會(huì)被加載)。實(shí)現(xiàn)方式就是在異步代碼中使用import()語(yǔ)法引入文件,這樣就起到懶加載的作用。

  1. document.getElementById('btn').addEventListener('click', () => { 
  2.     import(/*webpackChunkName: 'test'*/./test) 
  3.         .then(() => {}) 
  4.         .catch(() => {}) 
  5. }) 

2.2.5 預(yù)加載

預(yù)加載主要用于加載未來(lái)可能使用的文件,利用預(yù)加載可以在使用之前提前加載文件。對(duì)于預(yù)加載,其實(shí)是在父chunk完成加載后瀏覽器空閑了再加載資源。通過(guò)在import()語(yǔ)法中添加webpackPrefetch:true來(lái)實(shí)現(xiàn)預(yù)加載。

  1. import(/*webpackChunkName: 'test',webpackPrefetch: true*/./test) 
  2.         .then(() => {}) 
  3.         .catch(() => {}) 

本文轉(zhuǎn)載自微信公眾號(hào)「前端點(diǎn)線面」,作者前端點(diǎn)線面。轉(zhuǎn)載本文請(qǐng)聯(lián)系前端點(diǎn)線面公眾號(hào)。

 

責(zé)任編輯:武曉燕 來(lái)源: 前端點(diǎn)線面
相關(guān)推薦

2021-09-06 06:45:06

WebpackMindMasterEntry

2019-03-15 15:00:49

Webpack構(gòu)建速度前端

2019-03-26 10:02:16

WebpackJavascript前端

2020-09-19 21:26:56

webpack

2021-12-24 08:01:44

Webpack優(yōu)化打包

2015-09-16 14:37:50

Android性能優(yōu)化運(yùn)算

2015-09-16 13:54:30

Android性能優(yōu)化渲染

2015-09-16 15:48:55

Android性能優(yōu)化電量

2017-07-11 15:50:11

前端webpack2優(yōu)化

2021-09-10 11:12:50

開(kāi)發(fā)技能代碼

2021-09-14 09:35:34

MySQL查詢解析優(yōu)化器

2009-08-13 15:49:18

ASP.NET性能優(yōu)化

2020-06-11 13:03:04

性能優(yōu)化緩存

2009-08-13 16:22:18

ASP.NET性能優(yōu)化

2024-02-02 10:38:06

虛擬文件系統(tǒng)VFS

2021-11-09 09:57:46

Webpack 前端分包優(yōu)化

2021-12-08 22:48:16

Webpack異步同步

2009-10-20 18:32:25

Oracle 10g

2010-03-18 10:56:29

無(wú)線傳感器

2018-04-19 15:13:53

javascriptwebpackvue.js
點(diǎn)贊
收藏

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

国产乱淫av片免费| 无码人妻一区二区三区在线| 1769在线观看| 精品亚洲欧美一区| 久久久久久噜噜噜久久久精品| 亚洲熟女乱综合一区二区三区| 亚洲成人一区在线观看| 亚洲综合无码一区二区| 日韩精品一线二线三线| 亚洲国产日韩在线观看| 免费国产亚洲视频| 欧美国产乱视频| 五月天精品在线| 中文字幕日韩高清在线| 欧美在线观看你懂的| 成人av在线播放观看| 国产精品久久久久一区二区国产| 国产精品一区二区久激情瑜伽| 欧美亚洲国产日本| 少妇久久久久久被弄高潮| 九一精品国产| 欧美精品一区二区三区视频| 日本人视频jizz页码69| av老司机免费在线| 日韩久久一区二区| 日本一区二区三区www| 亚洲国产日韩在线观看| 久久精品国产网站| 欧美在线一区二区三区四| 午夜少妇久久久久久久久| 日韩高清欧美| 亚洲少妇中文在线| 日本69式三人交| 激情久久免费视频| 欧美日韩国产电影| 欧美日韩亚洲一二三| 草草视频在线| 亚洲一区二区在线观看视频| 亚洲成人动漫在线| 麻豆视频在线免费观看| 国产精品蜜臀在线观看| 欧洲一区二区日韩在线视频观看免费| 污污网站免费在线观看| 国产99久久久精品| 99电影在线观看| 国产日韩一级片| 韩国成人福利片在线播放| 国产精品久久久久久久久久久不卡 | 在线视频欧美日韩| 人妻av无码一区二区三区| 三级精品视频| 日韩精品欧美激情| 野外性满足hd| 国产99久久| 亚洲香蕉在线观看| 欧美人妻一区二区三区 | 亚洲国产一区二区三区在线| 成人h小游戏| 国产精品护士白丝一区av| 日韩视频在线播放| 日韩精品成人av| 亚洲情趣在线观看| 欧美交换配乱吟粗大25p| 黄色的视频在线观看| 亚洲一区欧美一区| 免费av观看网址| 日韩电影免费观看高清完整版| 狠狠躁夜夜躁久久躁别揉| 日av中文字幕| 成人做爰视频www网站小优视频| 在线精品视频一区二区| 少妇一级淫免费播放| 高清久久精品| 亚洲精品电影网在线观看| 91网站免费视频| 不卡一区综合视频| 欧美成人激情图片网| 久久久香蕉视频| 国产精品一二| 国产精品夜色7777狼人| 国产suv精品一区二区69| 成人在线视频一区二区| 欧美大香线蕉线伊人久久| 国产精品ⅴa有声小说| 亚洲精选免费视频| 久色视频在线播放| 久久69成人| 日韩一区二区三区视频在线| aa一级黄色片| 99久久精品网站| 久久全国免费视频| 中文字幕免费在线看| 国产一区二区日韩精品| 久久久福利视频| 欧美成人精品一区二区男人看| 一区二区成人在线观看| 黄色国产小视频| 视频免费一区二区| 国产亚洲精品美女久久久久| 欧美日韩精品亚洲精品| 日韩中文字幕区一区有砖一区| 91视频国产一区| 青青久草在线| 亚洲精品成人天堂一二三| 日韩有码免费视频| 成人高潮a毛片免费观看网站| 亚洲香蕉伊综合在人在线视看| 午夜写真片福利电影网| 日韩高清不卡一区二区| 成人午夜电影在线播放| 在线观看免费版| 欧美日韩在线免费观看| 三级网站免费看| 日韩av专区| 欧美在线视频在线播放完整版免费观看| 国产精品久久久久久久一区二区 | 在线观看亚洲成人| 日本美女视频网站| 欧美xxxx中国| 日韩av毛片网| 天堂av在线免费| 亚洲乱码国产乱码精品精可以看| 少妇性l交大片| 欧美综合精品| 欧美激情免费视频| 91久久精品无码一区二区| 久久青草欧美一区二区三区| 青青视频免费在线| av在线亚洲一区| 中文字幕亚洲情99在线| 五月婷婷激情视频| av激情综合网| 成人免费观看在线| 99ri日韩精品视频| 欧美日韩ab片| 精品人妻一区二区三区四区不卡| 国产精品美女久久福利网站| 国产成人精品无码播放| 欧美猛男同性videos| 97免费视频在线| 色噜噜一区二区三区| 亚洲一区中文在线| 少妇极品熟妇人妻无码| 国内精品久久久久久久97牛牛| 亚洲综合国产精品| 成人在线观看免费网站| 欧美一区二区三区免费| √天堂中文官网8在线| 精品中文字幕一区二区| 伊人久久大香线蕉午夜av| 欧美一级网址| 久久香蕉国产线看观看av| 136福利视频导航| 自拍偷拍欧美激情| 佐佐木明希电影| 激情成人亚洲| 国产中文一区二区| 欧美粗大gay| 在线观看欧美成人| 一卡二卡在线视频| 亚洲精品亚洲人成人网在线播放| 在线免费黄色小视频| 欧美黄色一区| 国产伦精品一区二区三区视频黑人 | 中文字幕中文在线| 综合天天久久| 成人综合色站| аⅴ资源天堂资源库在线| 日韩精品在线观看网站| 91视频在线视频| 中文字幕日韩av资源站| 日韩欧美色视频| 亚洲欧洲日本mm| 日本一区视频在线观看免费| 超薄肉色丝袜脚交一区二区| 久热精品视频在线免费观看| 后进极品白嫩翘臀在线视频| 无码av免费一区二区三区试看 | 91精品国产九九九久久久亚洲| 日本天堂影院在线视频| 欧美日韩综合不卡| 久久免费视频精品| 久久免费国产精品| 超碰中文字幕在线观看| 亚洲精品美女91| 亚洲成人一区二区三区| 日本伊人久久| 全球成人中文在线| 黄色免费在线看| 亚洲国产精品成人av| 中文字幕人妻丝袜乱一区三区| 亚洲欧美区自拍先锋| 一级特级黄色片| 激情久久五月天| 精品无码国模私拍视频| 三上亚洲一区二区| 国产专区一区二区| 亚洲一区导航| 热久久99这里有精品| gogogogo高清视频在线| 国产午夜精品麻豆| www.av导航| 欧美日韩在线精品一区二区三区激情 | 欧美aaaaa级| 91丝袜美腿美女视频网站| 天堂在线中文网官网| 欧美另类在线播放| 国产免费视频在线| 亚洲第一网中文字幕| 在线视频欧美亚洲| 色综合天天综合色综合av | xxxxx日韩| 亚洲国产精品人人爽夜夜爽| 91在线观看喷潮| 色综合网站在线| 国产网址在线观看| 亚洲日本va午夜在线影院| 扒开jk护士狂揉免费| eeuss影院一区二区三区| 最新av免费在线观看| 视频一区视频二区在线观看| 国产亚洲黄色片| 女主播福利一区| 一区二区日本伦理| 国内成人自拍| 欧美日本韩国在线| 久久porn| 国产欧美日韩在线播放| 视频在线亚洲| 444亚洲人体| 99久热在线精品视频观看| 国产精品看片资源| 日韩三区免费| 欧美在线不卡区| 鲁鲁在线中文| 国内精品400部情侣激情| 性爱视频在线播放| 美女av一区二区| 爆操欧美美女| 久久亚洲精品视频| 免费大片在线观看www| 中文字幕亚洲综合久久筱田步美| 日本啊v在线| 亚洲欧洲日产国产网站| 可以在线观看的av| 国产视频久久久| 韩国中文字幕2020精品| 亚洲女人被黑人巨大进入al| 好男人免费精品视频| 中文字幕无线精品亚洲乱码一区| 粉嫩一区二区三区国产精品| 在线看日韩欧美| 日本综合在线| 久久夜色精品亚洲噜噜国产mv| 黄色在线观看网站| 九九热99久久久国产盗摄| 日韩另类在线| 久久久久久久影院| 黑人巨大精品| 国产精品美女久久久久av超清| 成人国产网站| 91日韩在线播放| 亚洲3区在线| 久久久影院一区二区三区| 国产一区不卡| 99精品一区二区三区的区别| 欧美日韩视频一区二区三区| 精品国偷自产一区二区三区| 亚洲九九精品| 精品久久久久久中文字幕2017| 视频一区视频二区中文| 国产精品久久久久久久av福利| 国产成人午夜精品影院观看视频 | 欧美a大片欧美片| 日韩久久精品一区二区三区| 91精品国产乱码久久久久久久| 欧洲金发美女大战黑人| 99精品久久| 亚洲36d大奶网| 国产精品一区二区男女羞羞无遮挡| 久久久无码人妻精品无码| 2021中文字幕一区亚洲| 91禁男男在线观看| 亚洲制服欧美中文字幕中文字幕| 久久精品一二区| 欧美在线免费视屏| 国产农村老头老太视频| 亚洲精品国产精品乱码不99按摩 | 久久久人成影片一区二区三区观看| 日韩欧美精品一区二区三区| 国产精品视频999| 国产成人一二片| 亚洲精品影院| 99精品欧美| 国产精品自拍视频在线| 国产99一区视频免费| 一级片久久久久| 亚洲精品国久久99热| 91青青草视频| 精品免费国产二区三区| 一本一道波多野毛片中文在线| 国内精品久久久久久中文字幕 | 青青草视频在线免费直播| 国产精品99导航| 国产欧美三级电影| 天天爱天天做天天操| 久久久久久自在自线| 性一交一黄一片| 久久久不卡网国产精品一区| 久久这里只有精品国产| 欧美日韩亚洲综合| 亚洲 欧美 精品| 美女撒尿一区二区三区| 在线观看精品| 国产一区视频观看| 欧美成人高清| 999久久久精品视频| 亚洲国产精品成人综合| 亚洲欧美自拍视频| 亚洲第一福利网| 日本在线视频中文有码| 91精品国产综合久久香蕉922| 色综合综合网| 成人免费观看视频在线观看| 国产成人精品在线看| 日本福利片在线观看| 欧美视频精品在线观看| 久草在线青青草| 日产精品久久久一区二区福利| 成人爽a毛片| 欧美大黑帍在线播放| 国产高清不卡一区二区| 人妻久久一区二区| 91精品国产色综合久久不卡电影| 在线观看国产原创自拍视频| 国产成人小视频在线观看| 色天下一区二区三区| 国产午夜福利100集发布| 成人免费看黄yyy456| 精品亚洲永久免费| 日韩你懂的电影在线观看| av免费网站在线观看| 97免费资源站| 欧美69视频| 性色av浪潮av| 亚洲午夜久久久久久久久久久| 亚洲国产精品久久久久久6q| 欧美精品videos另类日本| 成人性生交大片免费看中文视频 | 精品国产电影| 国产日韩欧美高清免费| 毛片网站免费观看| 日本韩国一区二区三区视频| 国产在线视频网址| 国产精品久久久一区| 国产精品精品| 国产九九九视频| 亚洲成av人片在线| 香蕉av一区二区三区| 国外成人免费在线播放| 亚洲小说图片| 一级特黄性色生活片| 中文字幕一区二| 性猛交富婆╳xxx乱大交天津 | 亚洲图片都市激情| 国产一区二区三区在线观看免费| 永久免费看黄网站| 亚洲国产美女精品久久久久∴| 免费看男女www网站入口在线 | 日韩欧美国产骚| 成人亚洲性情网站www在线观看| 91九色单男在线观看| 在线成人亚洲| 国产aⅴ激情无码久久久无码| 欧美日本在线看| 欧美人与禽性xxxxx杂性| 久久久久欧美| 强制捆绑调教一区二区| 欧洲第一无人区观看| 亚洲精品日韩在线| 免播放器亚洲| av免费在线播放网站| 国产精品全国免费观看高清 | 久久av色综合| 鲁片一区二区三区| 精品一区二区三区久久| 国产在线欧美在线| 亚洲天堂男人天堂| 亚洲一区二区三区免费| 久久久久久久激情| 综合久久综合久久| 毛片免费在线| 99久久伊人精品影院| 秋霞午夜av一区二区三区| 欧美成人一区二区三区高清| 一本色道久久88综合亚洲精品ⅰ| 欧州一区二区三区| 不卡av免费在线| 亚洲国产一区二区三区| 日本精品在线|