久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

vue的ssr服務端渲染示例詳解

瀏覽:54日期:2022-09-30 11:25:49

為什么使用服務器端渲染 (SSR)

更好的 SEO,由于搜索引擎爬蟲抓取工具可以直接查看完全渲染的頁面。 請注意,截至目前,Google 和 Bing 可以很好對同步 JavaScript 應用程序進行索引。在這里,同步是關鍵。如果你的應用程序初始展示 loading 菊花圖,然后通過 Ajax 獲取內容,抓取工具并不會等待異步完成后再行抓取頁面內容。也就是說,如果 SEO 對你的站點至關重要,而你的頁面又是異步獲取內容,則你可能需要服務器端渲染(SSR)解決此問題。 更快的內容到達時間 (time-to-content),特別是對于緩慢的網絡情況或運行緩慢的設備。無需等待所有的 JavaScript 都完成下載并執行,才顯示服務器渲染的標記,所以你的用戶將會更快速地看到完整渲染的頁面。通常可以產生更好的用戶體驗,并且對于那些「內容到達時間(time-to-content) 與轉化率直接相關」的應用程序而言,服務器端渲染 (SSR) 至關重要。

使用服務器端渲染 (SSR) 時還需要有一些權衡之處:

開發條件所限。瀏覽器特定的代碼,只能在某些生命周期鉤子函數 (lifecycle hook) 中使用;一些外部擴展庫 (external library) 可能需要特殊處理,才能在服務器渲染應用程序中運行。 涉及構建設置和部署的更多要求。與可以部署在任何靜態文件服務器上的完全靜態單頁面應用程序 (SPA) 不同,服務器渲染應用程序,需要處于 Node.js server 運行環境。 更多的服務器端負載。在 Node.js 中渲染完整的應用程序,顯然會比僅僅提供靜態文件的 server 更加大量占用 CPU 資源 (CPU-intensive - CPU 密集),因此如果你預料在高流量環境 (high traffic) 下使用,請準備相應的服務器負載,并明智地采用緩存策略。

目錄結構

vue的ssr服務端渲染示例詳解

1、定義打包命令 和 開發命令

開發命令是用于客戶端開發

打包命令用于部署服務端開發

?watch 便于修改文件再自動打包

'client:build': 'webpack --config scripts/webpack.client.js --watch','server:build': 'webpack --config scripts/webpack.server.js --watch',

'run:all': 'concurrently 'npm run client:build' 'npm run server:build''

為了同時跑client:build 和 server:build

1.1 package.json

{ 'name': '11.vue-ssr', 'version': '1.0.0', 'description': '', 'main': 'index.js', 'scripts': { 'client:dev': 'webpack serve --config scripts/webpack.client.js', 'client:build': 'webpack --config scripts/webpack.client.js --watch', 'server:build': 'webpack --config scripts/webpack.server.js --watch', 'run:all': 'concurrently 'npm run client:build' 'npm run server:build'' }, 'keywords': [], 'author': '', 'license': 'ISC', 'dependencies': { 'concurrently': '^5.3.0', 'koa': '^2.13.1', 'koa-router': '^10.0.0', 'koa-static': '^5.0.0', 'vue': '^2.6.12', 'vue-router': '^3.4.9', 'vue-server-renderer': '^2.6.12', 'vuex': '^3.6.0', 'webpack-merge': '^5.7.3' }, 'devDependencies': { '@babel/core': '^7.12.10', '@babel/preset-env': '^7.12.11', 'babel-loader': '^8.2.2', 'css-loader': '^5.0.1', 'html-webpack-plugin': '^4.5.1', 'vue-loader': '^15.9.6', 'vue-style-loader': '^4.1.2', 'vue-template-compiler': '^2.6.12', 'webpack': '^5.13.0', 'webpack-cli': '^4.3.1', 'webpack-dev-server': '^3.11.2' }}

1.2 webpack.base.js 基礎配置

// webpack打包的入口文件 , 需要導出配置// webpack webpack-cli// @babel/core babel的核心模塊 // babel-loader webpack和babel的一個橋梁// @babel/preset-env 把es6+ 轉換成低級語法// vue-loader vue-template-compiler 解析.vue文件 并且編譯模板// vue-style-loader css-loader 解析css樣式并且插入到style標簽中, vue-style-loader支持服務端渲染const path = require(’path’);const HtmlWebpackPlugin = require(’html-webpack-plugin’);const VueLoaderPlugin = require(’vue-loader/lib/plugin’)module.exports = { mode: ’development’, output: {filename: ’[name].bundle.js’ ,// 默認就是main, 默認是dist目錄path:path.resolve(__dirname,’../dist’) }, module: {rules: [{ test: /.vue$/, use: ’vue-loader’}, { test: /.js$/, use: {loader: ’babel-loader’, // @babel/core -> preset-envoptions: { presets: [’@babel/preset-env’], // 插件的集合 } }, exclude: /node_modules/ // 表示node_modules的下的文件不需要查找}, { test: /.css$/, use: [’vue-style-loader’, {loader: ’css-loader’,options: { esModule: false, // 注意為了配套使用vue-style-loader} }] // 從右向左執行}] }, plugins: [new VueLoaderPlugin() // 固定的 ]}

1.3 webpack.client.js 配置是客戶端開發配置 就是正常的vue spa開發模式的配置

const {merge} = require(’webpack-merge’);const base =require(’./webpack.base’);const path = require(’path’)const HtmlWebpackPlugin = require(’html-webpack-plugin’)module.exports = merge(base,{ entry: {client:path.resolve(__dirname, ’../src/client-entry.js’) }, plugins:[new HtmlWebpackPlugin({ template: path.resolve(__dirname, ’../public/index.html’), filename:’client.html’ // 默認的名字叫index.html}), ]})

1.4 webpack.server.js配置是打包后 用于服務端部署時引入的使用

const base =require(’./webpack.base’)const {merge} = require(’webpack-merge’);const HtmlWebpackPlugin = require(’html-webpack-plugin’)const path = require(’path’)module.exports = merge(base,{ target:’node’, entry: {server:path.resolve(__dirname, ’../src/server-entry.js’) }, output:{libraryTarget:'commonjs2' // module.exports 導出 }, plugins:[new HtmlWebpackPlugin({ template: path.resolve(__dirname, ’../public/index.ssr.html’), filename:’server.html’, excludeChunks:[’server’], minify:false, client:’/client.bundle.js’ // 默認的名字叫index.html}), ]})

excludeChunks:[‘server’] 不引入 server.bundle.js包

client 是變量minify 是不壓縮

filename是打包后的生成的html文件名字

template: 模板文件

2、編寫html文件

兩份:

2.1 public/index.html

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <title>Document</title></head><body> <div id='app'></div></body></html>

2.2 public/index.ssr.html

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <title>Document</title></head><body> <!--vue-ssr-outlet--> <!-- ejs模板 --> <script src='http://www.gepszalag.com/bcjs/<%=htmlWebpackPlugin.options.client%>'></script></body></html>

<!--vue-ssr-outlet--> 是服務端渲染dom用到的插槽位置 固定寫法<%=htmlWebpackPlugin.options.client%> 填充htmlwebpackplugin的變量3、按照正常的vue開發, 編寫對應文件

定義一個app.js文件

src/app.js

入口改裝成了函數 目的是服務端渲染時 每次訪問的適合都可以通過這個工廠函數返回一個全新的實例,保證每個人訪問都可以拿到一個自己的實例

import Vue from ’vue’;import App from ’./App.vue’import createRouter from ’./router.js’import createStore from ’./store.js’// 入口改裝成了函數 目的是服務端渲染時 每次訪問的適合都可以通過這個工廠函數返回一個全新的實例,保證每個人訪問都可以拿到一個自己的實例export default () => { const router = createRouter(); const store = createStore() const app = new Vue({router,store,render: h => h(App) }); return { app, router,store }}

src/app.vue

<template> <div id='app'> <router-link to='/'>foo</router-link> <router-link to='/bar'>bar</router-link> <router-view></router-view> </div></template><script>export default {};</script>

src/component/Bar.vue

<template> <div> {{ $store.state.name }} </div></template><style scoped='true'>div { background: red;}</style><script>export default { asyncData(store){ // 在服務端執行的方法 ,只是這個方法在后端執行 console.log(’server call’) // axios.get(’/服務端路徑’)return Promise.resolve(’success’) }, mounted(){ // 瀏覽器執行 ,后端忽略 }}</script>

src/component/Foo.vue

<template> <div @click='show'>foo</div></template><script>export default { methods:{show(){ alert(1)} }}</script>

src/router.js

import Vue from ’vue’;import VueRouter from ’vue-router’;import Foo from ’./components/Foo.vue’import Bar from ’./components/Bar.vue’Vue.use(VueRouter);// 內部會提供兩個全局組件 Vue.component()// 每個人訪問服務器都需要產生一個路由系統export default ()=>{ let router = new VueRouter({mode:’history’,routes:[ {path:’/’,component:Foo}, {path:’/bar’,component:Bar}, // 懶加載,根據路徑動態加載對應的組件 {path:’*’,component:{render:(h)=>h(’div’,{},’404’) }}] }); return router;}//前端的路由的兩種方式 hash history// hash # // 路由就是根據路徑的不同渲染不同的組件 hash值特點是hash值變化不會導致頁面重新渲染,我們可以監控hash值的變化 顯示對應組件 (可以產生歷史記錄) hashApi 特點就是丑 (服務端獲取不到hash值,)// historyApi H5的api 漂亮。問題是刷新時會產生404。

src/store.js

import Vue from ’vue’;import Vuex from ’vuex’;Vue.use(Vuex);// 服務端中使用vuex ,將數據保存到全局變量中 window,瀏覽器用服務端渲染好的數據,進行替換export default ()=>{ let store = new Vuex.Store({state:{ name:’zhufeng’},mutations:{ changeName(state,payload){state.name = payload }},actions:{ changeName({commit}){// store.dispatch(’changeName’)return new Promise((resolve,reject)=>{ setTimeout(() => {commit(’changeName’,’jiangwen’);resolve(); }, 5000);}) }} }); if(typeof window!=’undefined’ && window.__INITIAL_STATE__){// 瀏覽器開始渲染了// 將后端渲染好的結果 同步給前端 vuex中核心方法store.replaceState(window.__INITIAL_STATE__); // 用服務端加載好的數據替換掉 } return store;}4、 定義入口文件

客戶端包的打包入口文件:

src/client-entry.js 用于客戶端的js入口文件

import createApp from ’./app.js’;let {app} = createApp();app.$mount(’#app’); // 客戶端渲染可以直接使用client-entry.js

src/server-entry.js 服務端的入口文件

是一個函數 在服務端請求時 再各自去執行, 給sever.js去執行用的

// 服務端入口import createApp from ’./app.js’;// 服務端渲染可以返回一個函數export default (context) => { // 服務端調用方法時會傳入url屬性 // 此方法是在服務端調用的 // 路由是異步組件 所以這里我需要等待路由加載完畢 const { url } = context; return new Promise((resolve, reject) => { // renderToString()let { app, router, store } = createApp(); // vue-routerrouter.push(url); // 表示永遠跳轉/路徑router.onReady(() => { // 等待路由跳轉完畢 組件已經準備號了觸發 const matchComponents = router.getMatchedComponents(); // /abc if (matchComponents.length == 0) { //沒有匹配到前端路由return reject({ code: 404 }); } else {// matchComponents 指的是路由匹配到的所有組件 (頁面級別的組件)Promise.all(matchComponents.map(component => { if (component.asyncData) { // 服務端在渲染的時候 默認會找到頁面級組件中的asyncData,并且在服務端也會創建一個vuex ,傳遞給asyncDatareturn component.asyncData(store) }})).then(()=>{ // 會默認在window下生成一個變量 內部默認就這樣做的 // 'window.__INITIAL_STATE__={'name':'jiangwen'}' context.state = store.state; // 服務器執行完畢后,最新的狀態保存在store.state上 resolve(app); // app是已經獲取到數據的實例}) }}) }) // app 對應的就是newVue 并沒有被路由所管理,我希望等到路由跳轉完畢后 在進行服務端渲染 // 當用戶訪問了一個不存在的頁面,如何匹配到前端的路由 // 每次都能產生一個新的應用}// 當用戶訪問bar的時候:我在服務端直接進行了服務端渲染,渲染后的結果返回給了瀏覽器。 瀏覽器加載js腳本,根據路徑加載js腳本,用重新渲染了bar

component.asyncData 是一個異步請求 等待請求結束后再 設置context.state = store.state; 此時 “window.INITIAL_STATE={“name”:“jiangwen”}”客戶端的store就能拿到window.INITIAL_STATE 重新賦值。

5、定義服務端文件 server.js , 用node部署的一個服務器,請求對應的模板文件

用了koa、koa-router做請求處理

vue-server-renderer是服務端渲染必備包

koa-static 是處理靜態資源的請求 比如js等文件

serverBundle 是打包后的js

template 是服務端入口打包后的html server:build

const Koa = require(’koa’);const app = new Koa();const Router = require(’koa-router’);const router = new Router();const VueServerRenderer = require(’vue-server-renderer’)const static = require(’koa-static’)const fs = require(’fs’);const path = require(’path’)const serverBundle = fs.readFileSync(path.resolve(__dirname, ’dist/server.bundle.js’), ’utf8’)const template = fs.readFileSync(path.resolve(__dirname, ’dist/server.html’), ’utf8’);// 根據實例 創建一個渲染器 傳入打包后的js 和 傳入模板文件const render = VueServerRenderer.createBundleRenderer(serverBundle, { template})// 請求到localhost:3000/ 根據請求url參數 -》 {url:ctx.url},傳給serverBundle 則 會根據服務端的打包的.js 路由系統 渲染出一份有該路由完整dom解構的頁面router.get(’/’, async (ctx) => { console.log(’跳轉’) ctx.body = await new Promise((resolve, reject) => {render.renderToString({url:ctx.url},(err, html) => { // 如果想讓css生效 只能使用回調的方式 if (err) reject(err); resolve(html)}) }) // const html = await render.renderToString(); // 生成字符串 // console.log(html)})// 當用戶訪問一個不存在的路徑的服務端路徑 我就返回給你首頁,你通過前端的js渲染的時候,會重新根據路徑渲染組件// 只要用戶刷新就會像服務器發請求router.get(’/(.*)’,async (ctx)=>{ console.log(’跳轉’) ctx.body = await new Promise((resolve, reject) => {render.renderToString({url:ctx.url},(err, html) => { // 通過服務端渲染 渲染后返回 if (err && err.code == 404) resolve(`not found`); console.log(html) resolve(html)}) })})// 當客戶端發送請求時會先去dist目錄下查找app.use(static(path.resolve(__dirname,’dist’))); // 順序問題app.use(router.routes());// 保證先走自己定義的路由 在找靜態文件app.listen(3000);

5.1 請求到localhost:3000/ 根據請求url參數 -》 {url:ctx.url},傳給serverBundle 則 會根據服務端的打包的.js 路由系統 渲染出一份有該路由完整dom解構的頁面

因為 / 對應的組件是Foo, 所以頁面展示Foo

vue的ssr服務端渲染示例詳解vue的ssr服務端渲染示例詳解vue的ssr服務端渲染示例詳解

網頁源代碼都是解析后的dom了 可以用于seo

5.2 如果請求了 http://localhost:3000/bar

vue的ssr服務端渲染示例詳解

那么就會走 /(.*)的路由

renderToString傳入url

就會走

server-entry.js文件的默認函數 這個js也是一個vue包含了所有客戶端原本的邏輯 只不過是放在服務端操作 。

url就是 /bar

根據路由 /bar 取出Bar組件

router跳到bar 此時頁面就會是bar組件了

同時執行asyncData函數 , 可能會改寫store或者其他數據

然后記得賦值 context.state = store.state 就會在window加上store的state對象

window.INITIAL_STATE={“name”:“jiangwen”}

vue的ssr服務端渲染示例詳解

store.js記得重新處理下(window.INITIAL_STATE

store.replaceState(window.INITIAL_STATE) 就是把服務端的狀態放在客戶端

vue的ssr服務端渲染示例詳解

dist/server.html 打包后,引入了/client.bundle.js 所以要有koa-static去做靜態請求處理

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <title>Document</title></head><body> <!--vue-ssr-outlet--> <!-- ejs模板 --> <script src='http://www.gepszalag.com/client.bundle.js'></script></body></html>6、 部署

6.1 執行命令 npm run run:all

'run:all': 'concurrently 'npm run client:build' 'npm run server:build''

就是打包了客戶端和服務端的資源包 包含js html 等

vue的ssr服務端渲染示例詳解

然后把整個server.js也放在服務器

執行node server.js 就能啟動node服務器了

6.2 server.js里面指向的server.bundle.js和server.html指向 對應服務器文件夾就行

vue的ssr服務端渲染示例詳解

命令解釋

client:dev 開發時用spa渲染模式開發, 不考慮ssr, client.bundle.js和 client.html是正常的spa部署時用到run:all 服務端渲染模式 是客戶端、服務端都打包

服務端使用時 ,client.bundle.js在瀏覽器使用, server.bundle.js 在服務器使用。

vue的ssr服務端渲染示例詳解

7、總結

1、SSR 首先要有個node服務器 、還有配合vue-server-renderer包使用。

2、正常的vue開發即可,考慮beforeMount 或 mounted生命周期不能在服務器端使用就行。

3、創建server.js 集合koa或者express 做請求解析 然后傳入 serverBundle和template給

VueServerRenderer.createBundleRenderer函數

得到一個render

4、render.renderToString傳入請求的路由 比如 /bar

5、此時會進入serverBundle默認函數(server-entry.js打包得出的),創建一個vue實例app, 分析路由 vue實例然后跳轉路由,此時都是服務端的vue實例的變動而已,還沒反應到頁面

6、執行對應組件的asyncData函數, 可能會改變store.state 那么在 context.state賦值就行

7、resolve(app) 此時 server.js里面的render根據此時的vue實例app的路由狀態解析出dom, 返回給頁面 ctx.body = …resolve(html);

8、此時頁面拿到正常路由匹配后的dom結構

9、html里面會有window.INITIAL_STATE={“name”:“zhufeng”} 相當于記錄了服務端的store狀態

vue的ssr服務端渲染示例詳解

10、客戶端執行到store時 其實沒有服務端那些改變后的狀態的 ,執行 store.replaceState(window.INITIAL_STATE); 就能替換了服務端的狀態

11、整體就是服務端客戶端都有一個js包, 提前在服務端跑js包 ,然后解析出dom, dom展現,服務端就結束了,剩下的邏輯交給客戶端的js去處理。

概念圖

vue的ssr服務端渲染示例詳解

官網:

vue-server-renderer 和 vue 必須匹配版本。 vue-server-renderer 依賴一些 Node.js 原生模塊,因此只能在 Node.js 中使用。我們可能會提供一個更簡單的構建,可以在將來在其他「JavaScript 運行時(runtime)」運行。 總結

到此這篇關于vue的ssr服務端渲染的文章就介紹到這了,更多相關vue ssr服務端渲染內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
主站蜘蛛池模板: 亚洲精品影院在线 | 天天干天天爽 | 九九亚洲 | 欧美一区二区三区免费视频 | 亚洲精品国精品久久99热 | 久久久久国产一区二区三区四区 | 九九综合九九综合 | 亚洲欧美一区二区三区在线 | 国产一区二区三区在线免费 | 国产片av| 看毛片的网站 | 在线免费国产视频 | 国产精品久久久久影院色老大 | 精品国产一区探花在线观看 | 在线观看黄 | 一区二区三区四区在线 | 国产美女精品人人做人人爽 | 成人午夜在线观看 | 香蕉成人啪国产精品视频综合网 | 成年人黄色一级毛片 | 视频一区在线 | 日本一区二区三区四区 | 久久亚洲综合 | 一区免费视频 | 五月天在线婷婷 | 色婷婷综合久久久久中文一区二区 | 日韩欧美一区二区三区久久婷婷 | 日韩午夜在线视频 | 91久久久久久久久 | 一区二区三区中文字幕 | 97色在线视频| 99色影院 | 午夜精 | 欧美高清视频在线观看 | 国产成人久久精品一区二区三区 | 日日摸日日爽 | 亚洲成人三级 | www在线看片 | 九色在线视频 | 精品一区二区三区国产 | 日韩久久久久久 | 2018天天操| 91免费在线 | 久久精品欧美一区二区三区麻豆 | 午夜影晥 | 国产欧美亚洲精品 | 久久se精品一区精品二区 | 欧美在线观看一区 | 色婷婷欧美 | 亚洲国产成人精品女人久久久 | 日韩三级视频 | 中文字幕在线观看 | 亚洲精品一区二区三区在线观看 | 久久成人一区 | 精品久久av | 日本不卡高字幕在线2019 | 欧美一区二区三区在线观看视频 | 人人做人人澡人人爽欧美 | 日韩高清在线 | 中文字幕 在线观看 | 精品国产一区二区三区久久久蜜月 | 亚洲精品一区在线观看 | 日本高清视频网站www | 久草视频在线播放 | 天天干狠狠 | 亚洲国产日韩欧美 | 欧美另类亚洲 | 精品久久久久久久久久久 | 男人的天堂久久 | 一级二级黄色大片 | 成人情趣视频 | 国产午夜视频 | 日韩成人av在线 | 国产无区一区二区三麻豆 | 亚洲国产午夜视频 | 91久久久久 | 日韩欧美在线看 | 成人免费视频网站在线观看 | 国产亚洲精品美女久久久久久久久久 | 草比网站| 日本在线小视频 | 色爱区综合 | 久久久99国产精品免费 | 日韩综合网 | 欧美1区| 久草青青 | 日韩字幕一区 | 色综合久久久久久久久久久 | 色黄网站 | 91精品国产高清久久久久久久久 | 一区二区三区在线观看视频 | 久久精品久久精品 | 国产午夜精品福利 | 91精品国产综合久久久久久丝袜 | 精品日韩| 日本久久www成人免 成人久久久久 | 欧美一级二级三级视频 | 免费看爱爱视频 | 美女视频一区 | 中文字幕日韩欧美一区二区三区 | 综合伊人| 日本综合视频 | 亚洲欧美中文日韩在线v日本 | 毛片99| 91麻豆精品国产91久久久资源速度 | 中文字幕一二三 | 午夜av电影| 精品视频久久久 | 一区二区三区四区在线视频 | 国产一区二区三区免费观看 | 国产精品一二三区视频 | 91免费影视 | 一区二区视频在线 | 久久久成人精品 | 久久久91精品国产一区二区精品 | 欧美日韩久久久 | 欧美一级在线观看 | 亚洲国产精品99久久久久久久久 | 成人av视 | 亚洲精品影院 | 岛国伊人 | 国产一级片免费观看 | 黄理论视频| 一级黄色大片在线 | 亚洲高清av| 91精品在线播放 | 国产视频导航 | 亚洲精品一区二区三区不 | 日本不卡视频 | 日韩在线视频观看 | 国产成人精品免费 | 在线免费一级片 | 久久久久久99| 一级大片免费观看 | 国产成人免费视频网站高清观看视频 | 久久亚洲欧美日韩精品专区 | 精品在线看 | 欧美一区二区三区aa大片漫 | 欧美性一区二区三区 | 国产区在线 | 国产精品久久精品 | 日韩欧美中字 | 色黄视频在线看 | 国产精品国产三级国产aⅴ9色 | 精品少妇一区二区三区 | 亚洲免费视频网 | 国产精品日日 | 欧美精品一区二区三区中文字幕 | 亚洲精品在线播放视频 | 91视频专区 | 成人精品免费视频 | 激情毛片 | 国产成人99久久亚洲综合精品 | 91在线网址 | 色在线看 | 成人三级av | 成人av影院 | 色婷婷综合在线 | 久久精品二区 | 久久国产精品久久久久久电车 | 99国产精品视频免费观看一公开 | 中文字幕在线免费视频 | 久久国产婷婷国产香蕉 | 偷拍自拍亚洲欧美 | 日韩免费在线 | 国产精品一区二区三区免费 | 一级a性色生活片毛片 | 亚洲欧美在线播放 | 99视频在线 | 日韩中文字幕一区二区高清99 | 欧美一级二级视频 | 日韩欧美手机在线 | 国产毛片aaa | 色网网站| 国产精品3区 | 欧美精品欧美精品系列 | 日本三级电影网站 | 97精品国产97久久久久久免费 | 国产精品丝袜视频 | 国产精品久久久久久久久免费桃花 | 日韩精品免费在线视频 | 夜夜精品视频 | 日韩三级电影免费观看 | 免费的一级毛片 | 99精品一区二区 | 久久久亚洲一区二区三区 | 亚洲免费在线看 | 999精品免费 | 中文字幕日韩专区 | 国产精品久久影院 | 亚洲精品66 | 日本高清h色视频在线观看 日日干日日操 | 日韩在线精品视频 | 一区二区三区四区精品 | 国产视频久久 | 午夜妇女aaaa区片 | 国产精品久久久久一区二区三区共 | 91免费在线看 | 在线观看毛片网站 | 亚洲欧美日韩国产综合精品二区 | 成人午夜毛片 | 性色av一区二区三区 | 黑人巨大精品欧美一区二区三区 | 二区三区在线观看 | 日本天天操 | 91久久久久| 国产精品色婷婷久久58 | 伊人电影综合 | 中文字幕日韩一区 | 一级电影免费看 | 成人免费视频 | 99热在线播放 | 久久久久久久av | 日韩精品视频在线播放 | 91久久| 在线播放黄色片网站 | 久爱国产 | a√免费视频 | 日韩国产欧美视频 | 日韩中文久久 | 超碰人操 | 久久首页 | 超碰中文字幕 | 在线观看成人高清 | 日韩一区二区在线播放 | 亚洲一区精品视频 | 又黄又爽的网站 | 天天摸天天操 | 青青草一区 | www中文字幕 | 男人av网 | 国产精品美女久久久久久久久久久 | 成人在线免费观看 | 欧美成人高清 | 欧美在线一区二区三区 | 国产精品一任线免费观看 | 精产国产伦理一二三区 | 精品久久久久久久久久久久久久 | 青青草免费在线 | 在线视频 亚洲 | 成人午夜在线观看 | 欧美成人免费观看 | 欧美视频网站 | 久久久影院 | 日韩欧美国产精品 | 九九热在线免费视频 | 91久久精品国产亚洲a∨麻豆 | 91av亚洲| 99久久久无码国产精品 | 欧美一区在线视频 | 国产精品美女久久久久久久久久久 | 激情六月婷 | 午夜影院免费视频 | 久久成人18免费网站 | 久久成人在线 | 成人av网站在线观看 | 刺激网 | 精品在线免费视频 | 亚洲国产精品免费 | 91精品国产自产91精品 | 日韩成人精品在线 | 人人干在线 | 中文字幕在线视频第一页 | 在线三级电影 | 成人a毛片 | 欧美一级特| 一区二区三区精品 | 三级欧美在线观看 | 日韩爱爱网 | 欧美精品福利视频 | 亚洲国产欧美一区二区三区久久 | 91人人爽人人爽人人精88v | 天天操网 | 国户精品久久久久久久久久久不卡 | 青青久在线视频 | 综合久草 | 九色在线观看 | 国产一区网站 | 91在线视频观看 | 天堂色网| 久久久久国产精品免费免费搜索 | 天天天天天天天天操 | 欧美一区二区三区在线视频观看 | 激情久久av一区av二区av三区 | 精品一区二区三区在线观看 | 香蕉国产精品 | 久视频在线观看 | 免费一二区 | 99re在线| 欧美日韩三级在线 | 欧美日韩国产一区二区三区 | 香蕉久久av一区二区三区 | www.成人在线视频 | 亚洲电影二区 | 欧美日韩美女 | 成人欧美一区二区三区黑人孕妇 | 亚洲九九 | 欧美视频免费看 | 亚洲一区| 一区视频 | 日本一二三视频 | 日韩在线成人 | 亚洲成人免费在线 | 丁香久久 | 一区二区三区视频免费 | 国产一区二区欧美 | 免费观看欧美一级 | 精品国产一区二区三区四 | 九九r热 | 亚洲精品二区 | baoyu133. con永久免费视频 | 精品免费 | 91亚洲视频 | 永久黄网站色视频免费 | 国产一级一级毛片女人精品 | 国产午夜手机精彩视频 | 黄色片在线观看视频 | 久热热热 | 精品99久久 | 91久久夜色精品国产网站 | 久久国产精品免费一区二区三区 | 国产精品一区二区久久久久 | 国产欧美综合一区二区三区 | 国产精品永久在线观看 | 日韩精品一区二区在线观看 | 日产精品久久久一区二区 | 国产一区| 国产精品久久久久久久久免费 | 91电影院 | 欧美精品xx | 免费看一区二区三区 | 欧美国产日韩另类 | a级黄色在线观看 | 国产婷婷在线观看 | 日韩精品一区二区三区中文在线 | 亚州成人 | 中文字幕精品一区久久久久 | 亚洲aⅴ网站 | 国产成人一区 | 91成人精品 | 婷婷久久综合 | 人操人人| 久久久精品 | 欧美精品一区三区 | 亚洲国产成人av | 久久国产亚洲精品 | 最新日韩在线观看视频 | 美女视频久久 | 日韩看片 | 最新中文字幕 | 欧美日韩中文在线 | 91观看在线视频 | 欧美极品视频 | 欧美成年黄网站色视频 | 国产成人在线视频 | 成人网av| 亚洲精品www久久久久久广东 | 天天干国产 | 欧美在线播放一区 | 日韩免费 | 久草免费福利 | 在线看av网址 | 国产精品揄拍一区二区久久国内亚洲精 | 国产精品福利在线观看 | 欧美国产日本一区 | 亚洲视频在线观看 | 国产人妖在线 | 免费福利网站 | 日本一区二区不卡视频 | 久久精品亚洲欧美日韩精品中文字幕 | 欧美成人激情视频 | 日韩成人免费电影 | 成人午夜小视频 | 国产91亚洲精品 | 日日操av | 欧美精品一区二区三区四区五区 | 久久激情五月丁香伊人 | 欧美日韩一区二区三区免费视频 | 欧美日一区二区 | 日本成人中文字幕 | 久久久久久久久久久九 | 国产成人啪精品午夜在线观看 | 精品一区视频 | 日本黄色一级 | 国产宾馆自拍 | 精品国产一区探花在线观看 | 在线观看亚洲精品视频 | 激情图区在线观看 | 亚洲精品在线免费 | 欧美一区二区视频 | 新99热 | 国产精品国色综合久久 | 久久久av| 久草热8精品视频在线观看 黄色片网站视频 | 国产一级免费网站 | 日本成人小视频 | 午夜精品久久久久久久白皮肤 | 男女羞羞视频在线观看 | 亚洲精品国产setv | 午夜激情视频在线观看 | 国产精品亚洲天堂 | 精品一区二区三区久久 | 一区二区免费看 | 欧美日韩亚洲一区 | 在线国产一区 | 日本亚洲欧美 | 国产一区免费在线观看 | 欧美麻豆 | 在线播放亚洲 | 丁香久久| 男人的天堂在线视频 | 成人午夜av| 久久精品黄| 中文精品一区二区三区 | а天堂中文最新一区二区三区 | 欧美日韩亚洲一区 | 日韩欧美一区二区三区免费观看 | 久久久久久一区 | 日日摸天天爽天天爽视频 | 日韩中文字幕av在线 | 91在线视频一区 | а天堂中文最新一区二区三区 | 91高清视频在线观看 | 中文字幕日韩在线 | 91中文字幕| 国产日韩欧美一区 | 粉嫩高清一区二区三区 | 91人人澡人人爽 | 亚洲国产精品va在线看黑人 | 欧美在线观看免费观看视频 | 成人精品三级av在线看 | 国产一区在线免费观看 | 午夜男人的天堂 | 欧美精产国品一二三区 | 高清中文字幕 | 青青久久久 | 国家aaa的一级看片 操操操夜夜操 | 国产精品久久av | 91黄色在线观看 | 特级做a爰片毛片免费看108 | 91精品免费在线观看 | 亚洲午夜精品片久久www慈禧 | 成人av免费看 | 亚洲一区二区三区四区五区中文 | 成人免费视频网站在线观看 | 国产第一亚洲 | 国产一级片在线播放 | 麻豆精品久久 | 一级a性色生活片久久毛片 夜夜视频 | 太平公主一级艳史播放高清 | 自拍一区视频 | 欧美日韩国产一级片 | 操视频网站 | 麻豆精品国产91久久久久久 | 中文字幕一区二区三区不卡 | 国产精品久久一区 | 久久精品中文 | 国产欧美精品一区二区 | 久久精品久久久久久久久久久久久 | 国产女精品| 伊人精品在线 | 91免费观看视频 | 精品福利在线视频 | 日本久久精品一区 | 亚洲色域网 | 精品一区二区久久久久久久网站 | 美女一级 | 91视频国产一区 | 超碰偷拍 | 国产精品.xx视频.xxtv | 黄色小视频在线免费观看 | 一级片在线观看 | 欧美一区二区久久久 | 色婷网 | 日精品 | 久久国产一区 | 中文字幕不卡在线 | 狠狠色狠狠色综合网 | 国产精品久久国产精品 | 欧美日韩亚洲国产 | 亚洲视频一区二区 | 北条麻妃一区二区免费播放 | 亚洲第一av | 中文字幕视频三区 | 午夜精品久久久久 | 国产成人精品一区二区三区视频 | 欧美一级二级视频 | 国产免费av一区二区三区 | 成人免费福利视频 | 伊人二区 | 国产免费一区二区三区 | 日韩国产在线观看 | 五月婷婷综合激情网 | 精品免费视频一区二区 | 亚洲乱码一区二区三区在线观看 | 精品无人乱码区1区2区3区 | 中文乱码一区 | 国产激情视频在线 | 日本久久久一区二区三区 | 欧美日韩精品久久久 | 国产精品婷婷午夜在线观看 | 这里有精品在线视频 | 中文字幕一区二区三区乱码在线 | 波多野结衣先锋影音 | 国产精品揄拍一区二区久久国内亚洲精 | 国产91在线 | 亚洲 | 午夜久久久 | 免费亚洲视频 | 日韩中文字幕无码一区二区三区 | 国产一页 | 一区二区三区在线免费观看 | 日韩一区二区免费视频 | 国产精品久久久久久久久动漫 | 国产精品久久久久久久久久久久久久 | 亚洲91精品 | 精品国产一区一区二区三亚瑟 | 最近免费中文字幕在线视频2 | 国产高清久久久 | 中文字幕日韩一区 | 久久草草影视免费网 | 久久视频在线 | 日本免费一区二区视频 | 国产一区二区三区免费 | 久久国产成人午夜av影院宅 | 亚洲国产精品久久久久久 | 久久99深爱久久99精品 | 91九色视频pron | 在线观看欧美一区二区三区 | www.久久 | 亚洲精品一区二三区不卡 | 中文字幕综合 | 久久精品首页 | 99热成人在线 | 国产午夜精品美女视频明星a级 | 日韩一区二区在线观看 | 在线99视频| 日本网站在线免费观看 | 久久久久久免费看 | 亚洲一区精品视频 | 亚洲视频一区在线播放 | 欧美一级二级三级视频 | 国产精品一区久久久久 | 亚洲成年人影院 | 色天天天天色 | 国产综合精品一区二区三区 | 中文字幕一区二区在线观看 | 精品国产乱码久久久久久蜜柚 | 日本三级在线视频 | 国产一级淫片a级aaa | 香蕉视频成人在线观看 | 日韩在线大片 | 天堂成人av | 五月在线视频 | 色爽女人免费 | 午夜理伦三级 | 日日综合 | 在线免费国产 | 伦理午夜电影免费观看 | 婷婷国产成人精品视频 | 欧美国产日韩一区 | 国产激情视频 | 国精产品一区二区三区 | 国内精品久久久久久中文字幕 | 久久精品99 | 午夜精品网站 | 色视频网站免费看 | 九九久久久 | 亚洲精品不卡 | 精品亚洲永久免费精品 | 国产精品久久久久久久久久新婚 | 国产一区视频网站 | 国产成人免费视频网站视频社区 | 久久久久久这里只有精品 | 日韩欧美国产一区二区三区 | 国产做a爰片久久毛片a我的朋友 | 中文字幕一区二区三区乱码图片 | 91高清在线| 在线激情视频 | 91视频免费观看 | 国产精品自拍一区 | 亚洲第一网站 | 91成人小视频 | 九九热这里只有精品在线观看 | 日韩国产一区二区三区 | 激情一区二区三区 | 天天干天天爽 | 中文字幕国产视频 | 2019国产精品 | 午夜精品久久久久久久久久久久 | 一级片视频免费 | 国产一级大片 | 日本免费www | 黄色av网站在线观看 | 免费毛片网 | 欧美日韩在线视频免费 | 99久久99久久精品 | 91中文字幕在线 | 免费视频爱爱太爽了 | 日本久久www成人免 成人久久久久 | 五月婷婷导航 | 青青久草 | 亚洲欧美高清 | 国产成人精品久久二区二区 | 国产成人在线免费观看 | 91精品国产综合久久精品 | 日韩视频一区二区三区 | av网站观看 | a成人| 国产一区二区三区在线 | 免费人成电影 | 国产一级特黄aaa大片 | 婷婷色5月 | 99在线视频观看 | 国产一级网站 | 欧美日韩国产一区二区三区 |