日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

webpack3的CommonsChunkPlugin插件详解

發(fā)布時(shí)間:2023/12/2 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 webpack3的CommonsChunkPlugin插件详解 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

webpack打出來的包在不做處理的情況下是非常大的,所有依賴都被塞進(jìn)一個(gè)文件中,文件中有業(yè)務(wù)代碼,有業(yè)務(wù)代碼依賴的第三方庫代碼,還有webpack生成的運(yùn)行時(shí)代碼等。這樣的一個(gè)文件不方便靜態(tài)資源緩存,并且初始化頁面的時(shí)候下載了所有的JS這是沒必要的,拖慢了頁面速度。所以對(duì)于webpack打包的資源文件進(jìn)行分割按需加載是很重要的一件事情。

webpack4都出來了為啥要寫一篇關(guān)于webpack3的文章。

目前webpack3應(yīng)用的還是很多,并且學(xué)習(xí)相關(guān)知識(shí)協(xié)查找過相關(guān)資料很多遍,所以這次總結(jié)一下通過webpack3分割代碼的方法,方便后期需要的時(shí)候方便查閱。

在webpack3中使用的分割thunk方法主要是使用webpack自帶的插件(webpack.optimize.CommonsChunkPlugin)實(shí)現(xiàn)的。

首先通過webpack來構(gòu)建項(xiàng)目

目錄結(jié)構(gòu):

|— src

? |— index.html

? |— indexa.js

? |— indexb.js

|— webpack.config.js

|— node_modules

? |— jquery/

indexa.js

import $ from 'jquery'$() // 調(diào)用一下console.log('我是indexa.js')

indexb.js

import $ from 'jquery'$() // 調(diào)用一下console.log('我是indexb.js')

webpack.config.js

// output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin')module.exports = {entry: {indexa: './src/indexa.js',indexb: './src/indexb.js'},output: {path: path.resolve('./dist/'),filename: '[name].[chunkHash].js'},plugins: [new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

上面的示例中有兩個(gè)入口,一個(gè)是pagea.js,另一個(gè)是pageb.js。這兩個(gè)入口都引入了jquery.js,并且打包結(jié)果中我們看到j(luò)query.js被同時(shí)打到了兩個(gè)入口文件中。

提取公共第三方庫jquery

這樣的結(jié)果顯然不是我們期望的,我們期望兩個(gè)入口都引入的jquery被打到單獨(dú)的包中,然后在兩個(gè)入口引入這個(gè)包即可。這就需要借助webpack.optimize.CommonsChunkPlugin插件,下面修改webpack.config.js文件為:

// output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin') let webpack = require('webpack') let CommonsChunkPlugin = webpack.optimize.CommonsChunkPluginmodule.exports = {entry: {indexa: './src/indexa.js',indexb: './src/indexb.js',jquery: ['jquery'] // 依賴的第三方庫node_modules中},output: {path: path.resolve('./dist/'),filename: '[name].[chunkHash].js'},plugins: [new CommonsChunkPlugin({name: 'jquery', // 如果有該名稱的chunk則選擇這個(gè)chunk提取公共文件,這里是jquery,如果沒有則生成的文件是這個(gè)名稱的chunk}),new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

通過CommonsChunkPlugin插件我們提取了在indexa和indexb中都引入的jquery庫這樣打包結(jié)果中pagea.js和pageb.js就大幅減小了。

提取自定義公共模塊

通常我們不止有第三方的公共模塊,我們自己也會(huì)寫一些公用的工具方法。現(xiàn)加入公用工具方法文件utils.js。

utils.js

function common () {console.log('我是工具方法') }export {common }

修改pagea.js文件

import $ from 'jquery' import {common} from './utils.js'common() // 新加的$() // 調(diào)用一下console.log('我是indexa.js')

修改pageb.js文件

import $ from 'jquery' import {common} from './utils.js'common() // 新加的$() // 調(diào)用一下console.log('我是indexb.js')

打包后發(fā)現(xiàn)自己的公共方法文件被打包到了jquery……js文件中了,我們并不希望這樣,因?yàn)榈谌綆煲话闶遣粫?huì)修改的,我們希望每次打包第三方庫的名稱不變,這樣有助于客戶端緩存。所以我們需要從當(dāng)前的jquery…js中提取出自己的公共方法文件。

分離utils.js文件和jquery等第三方庫文件

  • 修改webpack.config.js
  • // output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin') let webpack = require('webpack') let CommonsChunkPlugin = webpack.optimize.CommonsChunkPluginmodule.exports = {entry: {indexa: './src/indexa.js',indexb: './src/indexb.js',jquery: ['jquery'] // 依賴的第三方庫node_modules中},output: {path: path.resolve('./dist/'),filename: '[name].[chunkHash].js'},plugins: [new CommonsChunkPlugin({name: 'jquery', // 如果有該名稱的chunk則選擇這個(gè)chunk提取公共文件,這里是jquery,如果沒有則生成的文件是這個(gè)名稱的chunkminiChunks: Infinity // 這樣就只會(huì)打包出自身chunk和 webpack生成的一些文件}),new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

    通過打包結(jié)果發(fā)現(xiàn)我們自定義的模塊確實(shí)從jquery中提取了出來,但是卻打到了每個(gè)引入的頁面中,這也是我們接受不了的。

  • 從單個(gè)頁面中分離公共方法
  • 修改webpack.config.js文件如下:

    // output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin') let webpack = require('webpack') let CommonsChunkPlugin = webpack.optimize.CommonsChunkPluginmodule.exports = {entry: {indexa: './src/indexa.js',indexb: './src/indexb.js',jquery: ['jquery'] // 依賴的第三方庫node_modules中},output: {path: path.resolve('./dist/'),filename: '[name].[chunkHash].js'},plugins: [new CommonsChunkPlugin({name: 'jquery', // 如果有該名稱的chunk則選擇這個(gè)chunk提取公共文件,這里是jquery,如果沒有則生成的文件是這個(gè)名稱的chunkminChunks: Infinity // 這樣就只會(huì)打包出自身chunk和 webpack生成的一些文件}),new CommonsChunkPlugin({name: 'utils',chunks: ['indexa', 'indexb']}),new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

    打包結(jié)果如下,可以發(fā)現(xiàn)utils被提取了出來,這樣就我們的目的就達(dá)到了。

    minChunks的函數(shù)值

    我們發(fā)現(xiàn)第三方庫我們是通過entry字段手動(dòng)添加的,這樣比較麻煩,不能以后添加一個(gè)第三方庫我們就手動(dòng)修改一下entry的jquery數(shù)組。

    我們可以通過minChunks的值傳入一個(gè)函數(shù)來做,函數(shù)返回true則會(huì)被打包。修改webpack.config.js文件如下:

    // output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin') let webpack = require('webpack') let CommonsChunkPlugin = webpack.optimize.CommonsChunkPluginmodule.exports = {entry: {indexa: './src/indexa.js',indexb: './src/indexb.js',// 已經(jīng)不需要了 jquery: ['jquery'] // 依賴的第三方庫node_modules中},output: {path: path.resolve('./dist/'),filename: '[name].[chunkHash].js'},plugins: [new CommonsChunkPlugin({name: "vendor", // 修改jquery名稱為vendor,第三方庫集合minChunks: function (module, ) {// node_modules中出來的都打到這個(gè)文件中return module.context && module.context.includes("node_modules");}}),new CommonsChunkPlugin({name: 'utils',chunks: ['indexa', 'indexb']}),new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

    打包結(jié)果如下,只是將jquery…js的名稱換成了vendor…js其他沒有任何變化。

    讓moduleId固定下來

    通過上面兩張截圖的觀察我們可以發(fā)現(xiàn)indexb…js的chunkHash不一樣了,但是我們并沒有修改文件內(nèi)容。這是因?yàn)閣ebpack生成模塊的moduleId在變化。讓moduleId停止變化的插件有兩個(gè),一個(gè)是HashedModuleIdsPlugin,還有一個(gè)是NamedModulesPlugin。

    HashedModuleIdsPlugin: 該插件會(huì)根據(jù)模塊的相對(duì)路徑生成一個(gè)四位數(shù)的hash作為模塊id, 建議用于生產(chǎn)環(huán)境。

    NamedModulesPlugin: 當(dāng)開啟 HMR 的時(shí)候使用該插件會(huì)顯示模塊的相對(duì)路徑,建議用于開發(fā)環(huán)境。

    我們就選擇生產(chǎn)環(huán)境用的插件,修改webpack.config.js文件如下:

    // output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin') let webpack = require('webpack') let CommonsChunkPlugin = webpack.optimize.CommonsChunkPluginmodule.exports = {entry: {indexa: './src/indexa.js',indexb: './src/indexb.js',// 已經(jīng)不需要了 jquery: ['jquery'] // 依賴的第三方庫node_modules中},output: {path: path.resolve('./dist/'),filename: '[name].[chunkHash].js'},plugins: [new CommonsChunkPlugin({name: "vendor", // 修改jquery名稱為vendor,第三方庫集合minChunks: function (module) {// node_modules中出來的都打到這個(gè)文件中return module.context && module.context.includes("node_modules");}}),new CommonsChunkPlugin({name: 'utils',chunks: ['indexa', 'indexb']}),// 固定下來模塊的moduleIdnew HashedModuleIdsPlugin(),new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

    runtime和manifest

    其實(shí)vender中不止有node_module文件夾中的包,還包括

    runtime: 指在瀏覽器運(yùn)行時(shí),webpack 用來連接模塊化的應(yīng)用程序的所有代碼。其中包含:在模塊交互時(shí),連接模塊所需的加載和解析邏輯。包括瀏覽器中的已加載模塊的連接,以及懶加載模塊的執(zhí)行邏輯。

    manifest: 當(dāng)編譯器(compiler)開始執(zhí)行、解析和映射應(yīng)用程序時(shí),它會(huì)保留所有模塊的詳細(xì)要點(diǎn)。這個(gè)數(shù)據(jù)集合稱為 “Manifest”,當(dāng)完成打包并發(fā)送到瀏覽器時(shí),會(huì)在運(yùn)行時(shí)通過 Manifest 來解析和加載模塊。無論你選擇哪種模塊語法,那些 import 或 require 語句現(xiàn)在都已經(jīng)轉(zhuǎn)換為 __webpack_require__ 方法,此方法指向模塊標(biāo)識(shí)符(module identifier)。通過使用 manifest 中的數(shù)據(jù),runtime 將能夠查詢模塊標(biāo)識(shí)符,檢索出背后對(duì)應(yīng)的模塊。

    當(dāng)模塊做出改變的時(shí)候manifest也會(huì)改變,同時(shí)也會(huì)導(dǎo)致vender改變,最后導(dǎo)致vender的緩存失效,這種失效并不是因?yàn)関ender本身內(nèi)容的改變導(dǎo)致的,所以我們需要分離runtime和manifest。

    提取runtime和manifest

    修改webpack.config.js文件如下:

    // output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin') let webpack = require('webpack') let CommonsChunkPlugin = webpack.optimize.CommonsChunkPluginmodule.exports = {entry: {indexa: './src/indexa.js',indexb: './src/indexb.js'},output: {path: path.resolve('./'),filename: '[name].[chunkHash].js'},plugins: [new CommonsChunkPlugin({name: "vendor", // 修改jquery名稱為vendor,第三方庫集合minChunks: function (module) {// node_modules中出來的都打到這個(gè)文件中return module.context && module.context.includes("node_modules");}}),new CommonsChunkPlugin({name: 'utils',chunks: ['indexa', 'indexb']}),new CommonsChunkPlugin({name: 'manifest',minChunks: Infinity}),// 固定下來模塊的moduleIdnew HashedModuleIdsPlugin(),new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

    children字段和async字段的作用

    children和async作用于動(dòng)態(tài)加載模塊。如果沒有設(shè)置children,那么在動(dòng)態(tài)引入的多個(gè)腳本中公用的部分并不會(huì)被提取出來。如果設(shè)置了childrend: true,則公共部分會(huì)被提取到主腳本中。進(jìn)一步設(shè)置async字段,那么提取出來的公共部分不會(huì)在主腳本中,而會(huì)生成一個(gè)單獨(dú)文件異步引入。

    如果動(dòng)態(tài)引入腳本和主腳本有公共的部分,那么及時(shí)沒有設(shè)置children和async字段也會(huì)被提取。

    為了去除上面的干擾重建目錄。

    |— src|— index.html|— index.js|— child1.js|— child2.js|— webpack.config.js|— node_modules|— jquery/

    index.js

    改文件為主腳本,會(huì)動(dòng)態(tài)引入兩個(gè)腳本child1.js和child2.js

    require.ensure(['./child1.js'], function () { })require.ensure(['./child2.js'], function () { })

    child1.js

    import $ from 'jquery' import {common} from './utils.js'$() common()console.log('我是child1.js')

    child2.js(和child1.js內(nèi)容相同)

    import $ from 'jquery' import {common} from './utils.js'$() common()console.log('我是child2.js')

    webpack.config.js

    先正常打包,觀察結(jié)果。

    // output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin')module.exports = {entry: {index: './src/index.js'},output: {path: path.resolve('./'),filename: '[name].[chunkHash].js',chunkFilename: '[name].[chunkHash].js'},plugins: [new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

    下圖我們可以看出除了index.js還多了兩個(gè)js,這兩個(gè)就是通過動(dòng)態(tài)加載引入的js被單獨(dú)打包了,并且這兩個(gè)js中公共的部分并沒有被提取。還可以注意到這時(shí)候index.js是很小的。

    提取異步加載的js中公共部分

    // output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin') let CommonsChunkPlugin = webpack.optimize.CommonsChunkPluginmodule.exports = {entry: {index: './src/index.js'},output: {path: path.resolve('./'),filename: '[name].[chunkHash].js',chunkFilename: '[name].[chunkHash].js'},plugins: [new CommonsChunkPlugin({children: true}),new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

    添加children選項(xiàng)之后:

    動(dòng)態(tài)引入進(jìn)來的文件的公共部分被提取到主塊中了。兩個(gè)動(dòng)態(tài)引入文件的尺寸減小并且主腳本的尺寸變大了。

    將動(dòng)態(tài)引入的部分單獨(dú)打包

    // output中的path需要絕對(duì)路徑 let path = require('path') // 用于將打包的js文件注入到html文件中 let HtmlWebpackPlugin = require('html-webpack-plugin') let CommonsChunkPlugin = webpack.optimize.CommonsChunkPluginmodule.exports = {entry: {index: './src/index.js'},output: {path: path.resolve('./'),filename: '[name].[chunkHash].js',chunkFilename: '[name].[chunkHash].js'},plugins: [new CommonsChunkPlugin({children: true,async: true}),new HtmlWebpackPlugin({template: './src/index.html',filename: 'index.html'})] }

    我們可以看到index.js文件又減小了并且多了一個(gè)文件。

    以上就是我理解的CommonsChunkPlugin插件中children和async的用法。

    關(guān)于自定義動(dòng)態(tài)引入腳本打包的名字可參考webpack中實(shí)現(xiàn)按需加載

    注:

    hash:一個(gè)隨機(jī)值,每次打包都會(huì)改變,建議用于開發(fā)。

    chunkHash: 根據(jù)文件內(nèi)容生成一個(gè)隨機(jī)值,建議用于生產(chǎn)便于緩存。

    Infinity:創(chuàng)建一個(gè)公共chunk,但是不包含任何模塊,內(nèi)部是一些webpack生成的runtime代碼和chunk自身包含的模塊(如果chunk存在的話)。

    多CommonsChunkPlugin:第二次使用CommonsChunkPlugin插件的時(shí)候如果不指定chunks默認(rèn)針對(duì)前一個(gè)CommonsChunkPlugin插件生成的chunk做提取。

    children部分主腳本:引入異步腳本的腳本。

    總結(jié):

  • node_modules中第三方庫的提取可以通過miniChunks傳入function來控制。
  • 分離之后chunkHash還會(huì)變是應(yīng)為moduleId在改變可以使用插件HashedModuleIdsPlugin來固定下來
  • manifest和runtime文件提取可以通過miniChunks: Infinity 來完成
  • children字段設(shè)置為true,提取異步引入子文件的公共部分到主文件中
  • async字段配合children字段使用,提取異步引入子文件的公共部分到單獨(dú)文件中
  • 參考

    webpack4:連奏中的進(jìn)化

    Webpack4之SplitChunksPlugin規(guī)則

    詳解CommonsChunkPlugin的配置和用法

    CommonsChunkPlugin中children和async屬性詳解

    Webpack2中的NamedModulesPlugin與HashedModuleIdsPlugin

    runtime和manifest

    hashed-module-ids-plugin

    NamedModulesPlugin

    webpack中ensure方法和CommonsChunkPlugin中的children選項(xiàng)

    總結(jié)

    以上是生活随笔為你收集整理的webpack3的CommonsChunkPlugin插件详解的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    五月天久久激情 | 免费a级毛片在线看 | 综合激情久久 | av资源免费在线观看 | 97视频网址| 亚洲午夜精品久久久 | 国产一二三区在线观看 | 午夜精品影院 | 中文字幕网址 | 丝袜美腿在线视频 | 国产精品自产拍在线观看中文 | 日日夜夜免费精品 | 婷婷在线综合 | 一区二区三区在线观看免费 | 免费观看91视频大全 | 色综合天天干 | 精品一区二区综合 | 美女福利视频网 | 亚洲激精日韩激精欧美精品 | 亚av在线 | 欧美精品久久久久性色 | 免费三级大片 | 亚洲国产福利视频 | 奇米影音四色 | 亚洲精品永久免费视频 | 丁香婷婷综合网 | 丁香六月综合网 | 日韩超碰 | 五月综合网 | 精品国产美女在线 | 波多野结衣在线视频免费观看 | 大胆欧美gogo免费视频一二区 | 国产成人av福利 | 亚洲三级在线播放 | a'aaa级片在线观看 | 欧美午夜a | 成人午夜av电影 | 国产这里只有精品 | 色婷婷一区 | 国产精品久久久久久久久久久久久久 | 久久精品香蕉 | 国产免费人成xvideos视频 | av电影在线观看完整版一区二区 | 欧美日韩亚洲在线观看 | 99视频在线精品免费观看2 | www.久久视频 | 四虎成人精品永久免费av | 日韩精品视频第一页 | 黄网站www | 国产精品99久久免费黑人 | 中文字幕在线观看第三页 | 波多野结衣在线观看一区二区三区 | 国产又粗又长又硬免费视频 | 久久精品久久综合 | 久久99久久99精品 | 十八岁免进欧美 | 久久视频网| 三三级黄色片之日韩 | 精品9999 | 在线电影av | 国产精品大尺度 | 夜色成人av| av网站播放 | 国产中文在线观看 | 色婷婷精品大在线视频 | 亚洲视频免费视频 | 国产免费观看久久黄 | 久久久久久99精品 | 一区二区国产精品 | 中文字幕在线观看完整版电影 | 2024国产在线 | 91福利影院在线观看 | 午夜在线免费观看视频 | 久久精品国产免费看久久精品 | 国产1级毛片| 欧美日韩69| 成人污视频在线观看 | 日韩精品在线视频免费观看 | 97电影院在线观看 | 91精品欧美| av黄色免费看 | 国产精品欧美一区二区 | 色婷在线 | 黄色毛片电影 | 亚洲精品综合一区二区 | 蜜臀av免费一区二区三区 | 69av免费视频 | 国精产品999国精产品视频 | 成人一级黄色片 | 国产精品理论视频 | 免费av在线网 | 成人黄色一级视频 | 久久精品99国产精品 | 91av成人| 天堂网中文在线 | 国产精品亚洲a | 天天鲁天天干天天射 | 日韩成人免费在线电影 | 五月婷网 | 久久婷婷国产色一区二区三区 | 91视频下载 | 日日干天天射 | 色婷婷导航 | 少妇性aaaaaaaaa视频 | 一级欧美黄| 亚洲三区在线 | 色综合久久88色综合天天免费 | 91一区在线观看 | 亚洲精品伦理在线 | japanesefreesexvideo高潮 | 久久久夜色 | 久久观看最新视频 | 在线观看一区二区精品 | av电影在线不卡 | 91在线视频网址 | 国产精品情侣视频 | 99在线观看视频 | 国产日产亚洲精华av | 久久精品国产精品亚洲 | 四虎视频| www.香蕉| 欧美一区在线观看视频 | 国产色秀视频 | 99热这里有| 在线日本v二区不卡 | 国产夫妻性生活自拍 | 国产91区 | 亚洲黄色在线免费观看 | 99精品视频网 | 国产欧美综合在线观看 | 婷婷开心久久网 | 亚洲精品玖玖玖av在线看 | 日韩免费视频一区二区 | 国产男女免费完整视频 | 超碰人人乐 | 玖玖精品在线 | 91免费版在线 | 国产精品一区二区三区视频免费 | 久草在线视频资源 | 国产精品毛片久久蜜 | 久久婷婷五月综合色丁香 | 成人在线网站观看 | 欧美日韩在线观看一区二区 | 69视频在线| 日韩av片在线 | 色综合天天天天做夜夜夜夜做 | 亚洲国产欧美在线人成大黄瓜 | 久久久国产精品一区二区三区 | 五月激情站| 三级av在线免费观看 | 国产手机在线观看 | www.五月天激情 | 日韩一级电影在线观看 | 精品美女久久久久 | 精品免费一区 | 午夜视频一区二区 | 国产在线免费观看 | 久热电影| 亚洲视频1| 亚洲涩涩网站 | 视频在线观看亚洲 | 欧美高清成人 | 亚洲日本va午夜在线电影 | 91欧美视频网站 | 免费久久99精品国产婷婷六月 | 成人精品国产免费网站 | 精品久久电影 | 久久久久国产精品www | 最新av免费在线 | 人人爽人人澡人人添人人人人 | 一级淫片在线观看 | 二区三区在线视频 | 亚洲一区网 | 中文视频在线播放 | 亚洲视频在线免费观看 | 色a资源在线 | 青青河边草免费视频 | 在线观看av网 | 国产 日韩 欧美 中文 在线播放 | 91夫妻视频| 五月激情站 | a v在线观看 | 欧亚日韩精品一区二区在线 | 国内丰满少妇猛烈精品播放 | 日韩精品一区二区三区第95 | 91最新地址永久入口 | 久久96国产精品久久99漫画 | 亚洲丁香久久久 | 91九色蝌蚪 | 狠狠色噜噜狠狠狠狠2022 | 精品五月天 | 黄色片网站大全 | 国产麻豆精品久久 | 欧美性极品xxxx娇小 | 黄色免费网战 | 日韩av偷拍 | 中文有码在线视频 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 999电影免费在线观看 | 成人精品一区二区三区电影免费 | 在线网址你懂得 | 久久综合影音 | 成年人黄色免费网站 | a特级毛片| 香蕉在线影院 | 国产精品一区免费在线观看 | 久久精品艹 | 免费看的视频 | 国产又黄又爽又猛视频日本 | 99精品视频在线 | 日韩亚洲欧美中文字幕 | 中文字幕一区在线 | 免费看一级特黄a大片 | 欧美成人高清 | 精品国产1区 | 99视频国产精品 | 日韩伦理一区二区三区av在线 | 麻豆国产在线播放 | 六月丁香色婷婷 | 精品免费99久久 | 欧美在线视频一区二区三区 | 99精品视频免费全部在线 | 久久手机视频 | 福利精品在线 | 爱干视频 | 国产免费中文字幕 | 成人中文字幕av | 久久伊人综合 | 在线观看日韩免费视频 | 久久精品国产精品亚洲精品 | 黄网在线免费观看 | 我要看黄色一级片 | 日韩欧美视频在线免费观看 | 一级成人免费视频 | av大全在线播放 | 日本精品视频在线观看 | 91精品免费 | 手机看片1042 | 91九色丨porny丨丰满6 | 国产精品免费一区二区三区在线观看 | 欧美aaa视频 | 亚洲成人网av | 国产在线观看国语版免费 | 国产欧美精品在线观看 | 色搞搞| 91视频高清免费 | 24小时日本在线www免费的 | 黄色毛片在线观看 | 久草免费在线观看视频 | 丁香久久五月 | 亚洲精品国偷拍自产在线观看蜜桃 | 五月丁色| 在线观看不卡的av | 日日躁你夜夜躁你av蜜 | 日韩在线免费观看视频 | 亚洲免费精品视频 | 五月av在线| 国产精品成人久久久久久久 | 91成人精品一区在线播放 | 麻豆视频国产在线观看 | 国产精品一区二区久久久久 | 在线观看成人小视频 | 97视频在线观看播放 | 亚洲黄色av网址 | 欧美激情操| 最新免费av在线 | 国产青春久久久国产毛片 | 亚洲综合欧美精品电影 | 九九三级毛片 | av视屏在线 | 国产成人亚洲在线观看 | 99精品国产一区二区三区麻豆 | 在线视频麻豆 | 综合国产视频 | 91桃色在线播放 | 最新日韩视频在线观看 | 青草视频在线 | 日韩激情影院 | 国产精品av一区二区 | www.伊人网| 久久av免费电影 | 不卡的av片 | 久久爱992xxoo | 五月婷婷另类国产 | 国产韩国日本高清视频 | 亚州av免费 | 日韩精品在线看 | 激情欧美丁香 | 亚洲闷骚少妇在线观看网站 | 碰超人人 | 国产精品久久久久毛片大屁完整版 | 亚洲精品麻豆 | 久久女教师 | 中文字幕永久在线 | 欧美va天堂va视频va在线 | 香蕉久久久久久久 | 国产999精品久久久久久 | 18女毛片| 久久免费视频8 | 免费不卡中文字幕视频 | 国产一级视频在线免费观看 | 日韩av一区二区在线影视 | 高清不卡毛片 | 亚洲国产精品99久久久久久久久 | 成年人黄色av | avhd高清在线谜片 | 在线黄色国产 | 亚洲欧美综合精品久久成人 | 亚州国产视频 | 免费在线观看成人av | 最近中文字幕高清字幕免费mv | 麻豆影视在线观看 | 欧美精品久久人人躁人人爽 | 在线观看视频一区二区 | 久久99网 | 日韩电影中文字幕在线 | 美女网站免费福利视频 | 91成人在线免费观看 | 免费网站看v片在线a | 中文在线天堂资源 | 久久精品精品 | 成人在线你懂得 | 精品国产自在精品国产精野外直播 | 黄色网中文字幕 | 又爽又黄又无遮挡网站动态图 | 日韩一区二区三区视频在线 | 伊人热 | 91在线一区| av电影免费 | 精品麻豆入口免费 | 婷婷色网站 | 91系列在线 | 欧美一级片在线 | 日韩欧美在线观看一区二区三区 | 欧美午夜久久 | 99精品免费观看 | 日韩午夜视频在线观看 | 免费a视频在线观看 | 免费在线国产黄色 | 久久精品国产美女 | 欧美xxxx性xxxxx高清 | 视频福利在线 | www.亚洲精品 | 天堂va欧美va亚洲va老司机 | 91一区二区三区在线观看 | av官网| 丁香久久婷婷 | 奇米7777狠狠狠琪琪视频 | 日韩伦理片一区二区三区 | 玖玖精品视频 | 一区二区三区www | 亚洲欧美日韩中文在线 | 久久精品国产v日韩v亚洲 | 亚洲精品在线观看的 | 国产精品一区二区三区免费视频 | 成人黄色电影在线 | 久久免费视频在线观看 | 91久久人澡人人添人人爽欧美 | 美女av免费 | 97电影手机 | aⅴ精品av导航 | 国产精品免费看久久久8精臀av | www.天天射.com | 麻豆精品国产传媒 | 91大神精品视频在线观看 | 日本高清中文字幕有码在线 | 成人久久久久久久久 | 在线视频app | 久久免费福利视频 | 伊人五月天.com | 久久免费视频这里只有精品 | 欧美另类xxxx | www,黄视频| 国产一级精品视频 | 福利精品在线 | 日本中文字幕在线电影 | 亚洲精选久久 | av在线网站观看 | 日本资源中文字幕在线 | 天天色天天操天天爽 | 国模视频一区二区 | 永久黄网站色视频免费观看w | 国产又黄又爽无遮挡 | 天天插天天干 | 久久久污 | 草久中文字幕 | 国产精品久久久久久久久久免费 | 午夜丰满寂寞少妇精品 | 天天爱天天操天天爽 | 国产专区免费 | 夜夜夜草 | 亚洲婷婷综合色高清在线 | 久久久国产精品一区二区中文 | 丁香5月婷婷久久 | 激情电影在线观看 | 欧美色久 | 97在线视频网站 | 国产在线视频不卡 | 一区二区伦理 | 久久一区二 | 在线观看网站黄 | 国产精品成人一区二区 | 精品福利在线 | 四虎在线视频免费观看 | 欧美99热 | 国内久久久久久 | 最新国产精品久久精品 | 激情欧美丁香 | 韩国精品在线观看 | 国产97av | 四虎在线观看视频 | 激情伊人五月天 | 日日夜夜噜 | 婷婷色中文网 | 国产美女视频网站 | 国产一区二区不卡视频 | 五月天久久久 | 97天天综合网 | 天天色成人 | 国产麻豆视频 | 久久精品欧美一区二区三区麻豆 | 91av在线免费观看 | 久久久精品网站 | 中文在线a√在线 | 久久婷婷国产色一区二区三区 | 国产精品一区二区三区观看 | 久久三级视频 | 亚洲黄色区 | 中文字幕在线中文 | 日本久久久久久久久久久 | 亚洲a在线观看 | 99久久精品久久久久久动态片 | 亚洲国产精品电影 | 日韩欧美在线观看一区 | 最近日本韩国中文字幕 | 久久国产精品久久久久 | 三级免费黄色 | 国产伦理久久 | 韩国一区视频 | 99久久精品国产欧美主题曲 | 456免费视频| 日本福利视频在线 | 成人资源网 | 一二三四精品 | 国产精品网在线观看 | 日韩高清久久 | 六月色婷 | 国产91综合一区在线观看 | 成人av动漫在线观看 | 成人97视频一区二区 | 日韩精品视频在线观看免费 | 91丨九色丨首页 | 午夜黄网 | 免费91麻豆精品国产自产在线观看 | 国产精品自在线拍国产 | 中文字幕一区二区在线观看 | 欧美日韩三区二区 | 午夜视频亚洲 | 国产精品色婷婷 | 99久久久久国产精品免费 | 美女视频永久黄网站免费观看国产 | 日韩综合一区二区 | 国产一级视频免费看 | 99久久爱 | 91麻豆精品国产91久久久久久 | 欧美-第1页-屁屁影院 | 亚洲精品国精品久久99热 | 伊人色综合网 | 日韩在线播放av | 午夜av片| 黄色免费观看 | 亚洲精品88欧美一区二区 | 精品国产伦一区二区三区 | 伊人婷婷久久 | 日韩在线免费观看视频 | 久久99视频 | 少妇资源站 | 久草色在线观看 | 日韩免费av在线 | 色中射| 国产色视频网站2 | 久久不射电影院 | 天堂成人在线 | 日韩精品一区二区三区电影 | 亚洲综合成人专区片 | 国产精品欧美 | 免费观看黄色av | 精品视频国产 | 日韩特级黄色片 | 能在线看的av | 国产精品一区二区62 | 亚洲欧美偷拍另类 | 成人久久久久久久久 | 日本性高潮视频 | 国产精品18久久久久久不卡孕妇 | 91综合视频在线观看 | 黄污在线看 | 粉嫩高清一区二区三区 | 亚洲精品综合一区二区 | 精品女同一区二区三区在线观看 | 人人澡人人爽欧一区 | 国产精品国产亚洲精品看不卡 | 久久福利小视频 | 久久久久久久国产精品影院 | 国产精品久久久久久久久搜平片 | 97人人艹| 99精品国产99久久久久久97 | 国产精品一区二区白浆 | 蜜臀av性久久久久蜜臀av | 在线免费观看视频a | 美女免费网站 | 黄色app网站在线观看 | 在线观看免费黄色 | 超级碰99 | 国产在线无| 九九涩涩av台湾日本热热 | 日韩大片免费观看 | 在线国产黄色 | 欧美激情综合网 | 免费成人在线观看 | 99在线观看视频 | 探花视频免费观看高清视频 | 日韩网站在线观看 | 一区二区三区精品在线视频 | 久久久免费看片 | 亚洲视频高清 | 成人av教育 | www.com黄| 国产综合小视频 | 国产精品久久久久久久久久久久午 | 在线观看的黄色 | 特级西西444www大胆高清无视频 | 日p视频 | 97综合在线 | 免费亚洲视频在线观看 | 午夜黄色 | 亚洲电影久久 | 日韩专区一区二区 | www五月天 | 亚洲午夜不卡 | 欧美激情视频一区 | 99久久久久久久久久 | 麻豆视频免费入口 | 亚洲精品小区久久久久久 | 美女网站在线播放 | av 一区二区三区四区 | 91色九色 | www.com.日本一级 | 在线 高清 中文字幕 | 色福利网站 | 国际av在线 | 久久99视频免费 | 中文字幕国产视频 | 亚洲男人天堂a | 国产成人av网 | 菠萝菠萝蜜在线播放 | 91麻豆精品国产自产在线游戏 | 播五月综合 | 中文字幕免费中文 | 国产a级片免费观看 | 国产精品二区在线观看 | www.狠狠插.com | 亚洲精品国产成人av在线 | 操高跟美女 | 日韩在线三区 | 人人干天天干 | 999久久久久久 | av在线播放中文字幕 | 欧美一区二区三区激情视频 | 中文字幕乱偷在线 | 黄色av一区二区三区 | 日韩一区二区久久 | 日本aaa在线观看 | 一区 二区 精品 | 福利视频区 | 久久人人爽人人爽人人片av软件 | 日韩免费电影在线观看 | 91精选在线观看 | 久久免费视频网 | 日韩欧美中文 | 91一区二区三区久久久久国产乱 | 色爽网站 | 日韩中字在线 | 99视屏| 国产高清在线免费视频 | 婷婷5月色 | 国产涩涩在线观看 | 免费h精品视频在线播放 | 色99色| 亚洲精品无 | 91久久丝袜国产露脸动漫 | 欧美日韩aaaa | 成年人黄色av | 国产精品手机在线播放 | 精品国产乱码久久久久久浪潮 | 干天天 | 久久精品一区二区三区中文字幕 | 精品视频123区在线观看 | 91丨九色丨国产在线观看 | 中文字幕在线观看免费 | 欧美日韩国产二区三区 | 亚洲电影一区二区 | 日韩欧美视频 | 天天干天天操天天爱 | 2019中文字幕第一页 | www.干| 久久综合影视 | 久久国产免费 | 最新91在线视频 | 免费观看成年人视频 | 国产视频一区在线播放 | 亚洲精品久 | 一级久久久 | 久久久久国产精品免费免费搜索 | 国产成人精品一区二区三区福利 | 亚洲人xxx| 日本黄网站| 国产精品大片在线观看 | 亚洲免费成人av电影 | 国产成人精品a | 欧美激情xxxx性bbbb | 日韩欧美aaa | 国产精品国产三级国产aⅴ入口 | 久久九九网站 | 在线观看中文字幕 | 中文在线字幕观看电影 | www.在线看片.com | 国产成人av综合色 | 亚洲精品综合在线 | 久草爱 | 激情五月婷婷激情 | 国产精品日韩久久久久 | 91视频高清完整版 | 亚洲人成免费 | 色吊丝av中文字幕 | 日韩激情视频在线 | 99久久99久久 | 一本一本久久a久久精品综合小说 | 成人香蕉视频 | 美女久久精品 | 视频在线观看国产 | 日韩免费电影 | 日韩精品在线免费播放 | 超碰在线人 | 在线免费高清 | 国产精久久久久久妇女av | 99精品欧美一区二区蜜桃免费 | 91色蜜桃| 久久综合九色综合网站 | 不卡的av电影在线观看 | 亚洲成av人片在线观看香蕉 | 激情网色 | www在线观看视频 | 免费日韩视频 | 美女黄频在线观看 | 天天爱天天操 | 日韩av女优视频 | 黄网站污| 免费看网站在线 | 久草网首页 | 天天操天天射天天操 | 欧美一二三视频 | 激情丁香婷婷 | 欧美一二三四在线 | 8x8x在线观看视频 | 久久成人视屏 | 久热av在线 | 亚洲精品在线视频网站 | 日韩精品一区二区三区免费观看视频 | 麻花传媒mv免费观看 | 午夜视频免费 | 久久99国产精品免费网站 | 国产精品久久久久久久久久免费 | 97在线观看免费 | 日日干av | 日本少妇视频 | 日本性动态图 | 国产精品久久久久久久久久久久午 | 免费三级在线 | 黄色片亚洲 | 免费看麻豆 | 深爱激情久久 | 91高清视频免费 | 久久久网页 | 91精品国产麻豆国产自产影视 | 美女天天操 | 久久香蕉电影网 | 欧美日韩不卡在线 | 99久久精品国产网站 | 久久久久网址 | 亚洲精品中文在线 | 国产成人av一区二区三区在线观看 | 最近字幕在线观看第一季 | 伊人久久在线观看 | 不卡av免费在线观看 | 国产日韩在线视频 | 久久九九影院 | 久久免费观看少妇a级毛片 久久久久成人免费 | 在线免费高清视频 | 日韩黄色在线 | 在线电影a | 免费色网 | 91黄色在线看 | 亚洲少妇xxxx | 在线观看视频你懂的 | 亚洲三区在线 | 免费网站在线观看成人 | 在线观看911视频 | 国产精品中文字幕在线播放 | 波多野结衣视频一区二区三区 | 午夜精品久久一牛影视 | 日本黄色免费播放 | 日本中文字幕免费观看 | 九七视频在线观看 | 日韩免费中文字幕 | 日韩三级精品 | 国产小视频免费在线网址 | 天天爽人人爽 | 色综合久久久网 | 午夜18视频在线观看 | 色插综合 | 黄免费在线观看 | 国内亚洲精品 | 国产96在线 | 国产精品免费视频久久久 | 天天天天干 | 成人免费视频播放 | 日本久久中文 | 色姑娘综合天天 | 天天射天天射天天 | 伊人久久精品久久亚洲一区 | 亚洲精选在线 | 福利一区在线 | 欧美日bb| www.com久久久| 国产精品99页 | 果冻av在线 | 精品亚洲免a| 91精品久久久久久久91蜜桃 | 一级黄色毛片 | 欧美在线a视频 | 国产精品欧美一区二区 | 国产精品久久久久久久久搜平片 | 天天操天天爱天天爽 | 丁香婷婷久久久综合精品国产 | 免费高清国产 | 国产伦精品一区二区三区在线 | 中文字幕精品视频 | 久久天堂影院 | 18国产精品福利片久久婷 | 国内小视频 | 欧美日韩国产网站 | 毛片网在线播放 | 成人黄色在线 | 丁香婷婷激情五月 | 五月婷婷,六月丁香 | 国产成人av | 中文字幕在线观看完整 | www.国产视频 | 国产视频一区在线免费观看 | 亚洲精品国产精品乱码在线观看 | 99精品久久精品一区二区 | 97人人爽 | 亚洲免费在线观看视频 | 久久国产精品99久久久久 | 五月丁色| 国产精品久久久久aaaa九色 | 久久艹国产 | 黄色1级大片| 麻豆国产精品永久免费视频 | 日本中文字幕视频 | 日韩,中文字幕 | 天天操,夜夜操 | 免费看一级黄色 | 精品黄色在线观看 | 国产一区国产精品 | 色狠狠综合| 天天艹日日干 | 综合天堂av久久久久久久 | 天堂av在线免费 | 黄色在线成人 | 国产一级h| 精品中文字幕在线 | 久久视频一区二区 | 久久尤物电影视频在线观看 | 天天激情综合 | 日韩有码网站 | 91在线免费观看国产 | 成人精品视频 | 国产成人av网站 | 国产亚洲视频系列 | 97色在线观看 | 香蕉视频在线免费看 | av在线进入| 一级片视频免费观看 | 久久精品综合一区 | 国产高清在线免费视频 | 国产又粗又猛又黄又爽的视频 | 高清av免费观看 | 成人av.com| 欧美色道| 免费人成在线观看网站 | 亚洲国产合集 | 亚洲精品777 | 国产男女免费完整视频 | 在线免费观看视频一区二区三区 | 在线看一区二区 | 国产精品原创 | 国产日韩视频在线观看 | 四虎国产| 国产精品剧情 | 免费看片成人 | 中文字幕亚洲精品日韩 | 99色在线播放 | 久久不卡视频 | 天天操天天操天天操天天操天天操天天操 | 美女国产 | 国产成人久久精品亚洲 | 国产视频久久久久 | 色网站在线免费观看 | 亚洲视频高清 | 91亚洲精品久久久蜜桃 | 欧美性生活免费看 | 久久久亚洲网站 | 伊人亚洲综合网 | 精品美女在线观看 | 99久久精品午夜一区二区小说 | 人人插人人看 | 欧洲精品久久久久毛片完整版 | 91自拍91| 人人射人人 | 中文字幕一区二区三区久久 | 久久国产精品第一页 | www.夜夜爱 | 国产无套视频 | av中文国产 | 亚洲成人第一区 | 日韩电影在线观看一区二区三区 | 国产日本亚洲 | 免费人做人爱www的视 | 国产午夜精品一区二区三区在线观看 | 亚洲 欧洲 国产 日本 综合 | 精品国产一区二区三区久久 | 久久久久网站 | 日韩二级毛片 | av福利免费 | 久久久久女人精品毛片九一 | 99视频在线 | 久久精品一区八戒影视 | 亚洲精品国偷拍自产在线观看蜜桃 | 天天看天天干天天操 | 天堂av免费| 久久精品视频18 | 亚洲日韩欧美视频 | 国产精品久久久久亚洲影视 | 日韩av成人免费看 | 97操操操 | 91色吧 | 五月天av在线 | 好看的国产精品视频 | 久草免费资源 | 成人午夜电影网站 | 日韩av午夜 | 97精品超碰一区二区三区 | av成人动漫 | 国产成人一区二区三区在线观看 | 国产一区播放 | 亚洲国产精品99久久久久久久久 | 国产黄大片在线观看 | 99久久久国产精品免费99 | 涩涩爱夜夜爱 | 成年人国产视频 | 久久狠狠一本精品综合网 | 在线国产一区 | 免费观看国产精品视频 | 婷婷av色综合 | 欧美精品一区二区三区四区在线 | 欧美污污网站 | avwww在线 | 午夜影院在线观看18 | 天天操人人要 | 精品福利片 | 日韩在线观看第一页 | 91精品在线免费视频 | 毛片永久新网址首页 | a级黄色片视频 | 久久网站免费 | 日韩欧美aaa | 99精品一区二区 | 欧美国产日韩一区二区三区 | 成人在线播放视频 | 九九九九热精品免费视频点播观看 | 91系列在线 | 成人免费在线视频 | 97在线看片 | 久草在线综合 | 五月天激情视频在线观看 | 国产精品久久一区二区三区不卡 | 国产精品99久久久久久宅男 | 久热久草在线 | 欧美日韩精品在线 | av在线播放一区二区三区 | 国产91在线播放 | 在线观看免费 | 国产福利精品一区二区 | 中文在线8新资源库 | 日韩视频在线观看视频 | 不卡的av电影 | 超碰在线官网 | 久久99免费观看 | 亚洲精品免费看 | 国产一级性生活视频 | 久久精品国产精品 | 最新国产福利 | 国产一级片视频 | 中文字幕的 | 18久久久久久 | 亚洲欧美一区二区三区孕妇写真 | 亚洲手机av | 在线视频欧美日韩 | 亚洲理论电影 | 色橹橹欧美在线观看视频高清 | 欧美色综合 | 麻豆视频免费播放 | 久久久久久久久国产 | 亚洲精品乱码久久久久v最新版 | 91在线精品秘密一区二区 | 四虎海外影库www4hu | 国产视频18 | 亚洲丁香久久久 | 日韩欧美网址 | 婷婷激情av | 97色se | 亚洲综合欧美精品电影 | 国产一级片观看 | 久久99精品国产一区二区三区 | 婷婷六月综合亚洲 | 婷婷久久婷婷 | 九九九免费视频 | 五月婷婷色 | 人人爱人人添 | 182午夜在线观看 | 天天操天天摸天天爽 | 欧美大片在线看免费观看 | 日韩在线第一 | 在线观看视频中文字幕 | 久久久黄色免费网站 | 久久99视频| 最近日韩中文字幕中文 | 久久99精品国产一区二区三区 | 久久久99精品免费观看 | 欧美久久久久久久久久 | 美国人与动物xxxx | 国产色视频网站2 | 国产精品涩涩屋www在线观看 | av看片网址| 国产丝袜美腿在线 | 久久久久免费精品国产 | 免费看黄在线网站 | 国产精品原创av片国产免费 | 欧美性色网站 | 人人爱人人做人人爽 | 四月婷婷在线观看 | av免费试看| 亚洲草视频| 麻豆免费视频 | 视频在线99 | 国产精品美女久久久久久网站 | 成人综合婷婷国产精品久久免费 | 亚洲闷骚少妇在线观看网站 | 久久精品99久久久久久 | 天天插天天射 | 亚洲精品电影在线 | 久久精品国产精品亚洲 | 视频国产在线观看18 | 五月婷婷激情网 | www国产亚洲 | 国产高清av | 久久久久成人精品亚洲国产 | 91香蕉嫩草| 国产精品久久精品 | 亚洲伦理电影在线 | 麻豆精品传媒视频 | 一区二区成人国产精品 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 国产精品系列在线 | 免费黄色av电影 | 午夜视频在线观看一区二区三区 | 黄色大片日本 | 国产专区免费 | 精品在线观 | 亚洲精品在线资源 | 久久久久 免费视频 | 免费看片色 | 中文字幕亚洲欧美 | 麻豆免费观看视频 | 97视频在线看 | 久久无码精品一区二区三区 |