黄a在线观看-黄a在线-黄a大片-黄色片在线看-黄色毛片免费-黄色大片网站

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue的ssr服務(wù)端渲染示例詳解

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

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

更好的 SEO,由于搜索引擎爬蟲(chóng)抓取工具可以直接查看完全渲染的頁(yè)面。 請(qǐng)注意,截至目前,Google 和 Bing 可以很好對(duì)同步 JavaScript 應(yīng)用程序進(jìn)行索引。在這里,同步是關(guān)鍵。如果你的應(yīng)用程序初始展示 loading 菊花圖,然后通過(guò) Ajax 獲取內(nèi)容,抓取工具并不會(huì)等待異步完成后再行抓取頁(yè)面內(nèi)容。也就是說(shuō),如果 SEO 對(duì)你的站點(diǎn)至關(guān)重要,而你的頁(yè)面又是異步獲取內(nèi)容,則你可能需要服務(wù)器端渲染(SSR)解決此問(wèn)題。 更快的內(nèi)容到達(dá)時(shí)間 (time-to-content),特別是對(duì)于緩慢的網(wǎng)絡(luò)情況或運(yùn)行緩慢的設(shè)備。無(wú)需等待所有的 JavaScript 都完成下載并執(zhí)行,才顯示服務(wù)器渲染的標(biāo)記,所以你的用戶將會(huì)更快速地看到完整渲染的頁(yè)面。通??梢援a(chǎn)生更好的用戶體驗(yàn),并且對(duì)于那些「內(nèi)容到達(dá)時(shí)間(time-to-content) 與轉(zhuǎn)化率直接相關(guān)」的應(yīng)用程序而言,服務(wù)器端渲染 (SSR) 至關(guān)重要。

使用服務(wù)器端渲染 (SSR) 時(shí)還需要有一些權(quán)衡之處:

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

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

vue的ssr服務(wù)端渲染示例詳解

1、定義打包命令 和 開(kāi)發(fā)命令

開(kāi)發(fā)命令是用于客戶端開(kāi)發(fā)

打包命令用于部署服務(wù)端開(kāi)發(fā)

?watch 便于修改文件再自動(dòng)打包

'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''

為了同時(shí)跑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 基礎(chǔ)配置

// webpack打包的入口文件 , 需要導(dǎo)出配置// webpack webpack-cli// @babel/core babel的核心模塊 // babel-loader webpack和babel的一個(gè)橋梁// @babel/preset-env 把es6+ 轉(zhuǎn)換成低級(jí)語(yǔ)法// vue-loader vue-template-compiler 解析.vue文件 并且編譯模板// vue-style-loader css-loader 解析css樣式并且插入到style標(biāo)簽中, vue-style-loader支持服務(wù)端渲染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’ ,// 默認(rèn)就是main, 默認(rèn)是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} }] // 從右向左執(zhí)行}] }, plugins: [new VueLoaderPlugin() // 固定的 ]}

1.3 webpack.client.js 配置是客戶端開(kāi)發(fā)配置 就是正常的vue spa開(kāi)發(fā)模式的配置

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’ // 默認(rèn)的名字叫index.html}), ]})

1.4 webpack.server.js配置是打包后 用于服務(wù)端部署時(shí)引入的使用

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 導(dǎo)出 }, plugins:[new HtmlWebpackPlugin({ template: path.resolve(__dirname, ’../public/index.ssr.html’), filename:’server.html’, excludeChunks:[’server’], minify:false, client:’/client.bundle.js’ // 默認(rèn)的名字叫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://m.propowerdrill.cn/bcjs/<%=htmlWebpackPlugin.options.client%>'></script></body></html>

<!--vue-ssr-outlet--> 是服務(wù)端渲染dom用到的插槽位置 固定寫法<%=htmlWebpackPlugin.options.client%> 填充htmlwebpackplugin的變量3、按照正常的vue開(kāi)發(fā), 編寫對(duì)應(yīng)文件

定義一個(gè)app.js文件

src/app.js

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

import Vue from ’vue’;import App from ’./App.vue’import createRouter from ’./router.js’import createStore from ’./store.js’// 入口改裝成了函數(shù) 目的是服務(wù)端渲染時(shí) 每次訪問(wèn)的適合都可以通過(guò)這個(gè)工廠函數(shù)返回一個(gè)全新的實(shí)例,保證每個(gè)人訪問(wèn)都可以拿到一個(gè)自己的實(shí)例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){ // 在服務(wù)端執(zhí)行的方法 ,只是這個(gè)方法在后端執(zhí)行 console.log(’server call’) // axios.get(’/服務(wù)端路徑’)return Promise.resolve(’success’) }, mounted(){ // 瀏覽器執(zhí)行 ,后端忽略 }}</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);// 內(nèi)部會(huì)提供兩個(gè)全局組件 Vue.component()// 每個(gè)人訪問(wèn)服務(wù)器都需要產(chǎn)生一個(gè)路由系統(tǒng)export default ()=>{ let router = new VueRouter({mode:’history’,routes:[ {path:’/’,component:Foo}, {path:’/bar’,component:Bar}, // 懶加載,根據(jù)路徑動(dòng)態(tài)加載對(duì)應(yīng)的組件 {path:’*’,component:{render:(h)=>h(’div’,{},’404’) }}] }); return router;}//前端的路由的兩種方式 hash history// hash # // 路由就是根據(jù)路徑的不同渲染不同的組件 hash值特點(diǎn)是hash值變化不會(huì)導(dǎo)致頁(yè)面重新渲染,我們可以監(jiān)控hash值的變化 顯示對(duì)應(yīng)組件 (可以產(chǎn)生歷史記錄) hashApi 特點(diǎn)就是丑 (服務(wù)端獲取不到hash值,)// historyApi H5的api 漂亮。問(wèn)題是刷新時(shí)會(huì)產(chǎn)生404。

src/store.js

import Vue from ’vue’;import Vuex from ’vuex’;Vue.use(Vuex);// 服務(wù)端中使用vuex ,將數(shù)據(jù)保存到全局變量中 window,瀏覽器用服務(wù)端渲染好的數(shù)據(jù),進(jìn)行替換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__){// 瀏覽器開(kāi)始渲染了// 將后端渲染好的結(jié)果 同步給前端 vuex中核心方法store.replaceState(window.__INITIAL_STATE__); // 用服務(wù)端加載好的數(shù)據(jù)替換掉 } 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 服務(wù)端的入口文件

是一個(gè)函數(shù) 在服務(wù)端請(qǐng)求時(shí) 再各自去執(zhí)行, 給sever.js去執(zhí)行用的

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

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

5、定義服務(wù)端文件 server.js , 用node部署的一個(gè)服務(wù)器,請(qǐng)求對(duì)應(yīng)的模板文件

用了koa、koa-router做請(qǐng)求處理

vue-server-renderer是服務(wù)端渲染必備包

koa-static 是處理靜態(tài)資源的請(qǐng)求 比如js等文件

serverBundle 是打包后的js

template 是服務(wù)端入口打包后的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’);// 根據(jù)實(shí)例 創(chuàng)建一個(gè)渲染器 傳入打包后的js 和 傳入模板文件const render = VueServerRenderer.createBundleRenderer(serverBundle, { template})// 請(qǐng)求到localhost:3000/ 根據(jù)請(qǐng)求url參數(shù) -》 {url:ctx.url},傳給serverBundle 則 會(huì)根據(jù)服務(wù)端的打包的.js 路由系統(tǒng) 渲染出一份有該路由完整dom解構(gòu)的頁(yè)面router.get(’/’, async (ctx) => { console.log(’跳轉(zhuǎn)’) ctx.body = await new Promise((resolve, reject) => {render.renderToString({url:ctx.url},(err, html) => { // 如果想讓css生效 只能使用回調(diào)的方式 if (err) reject(err); resolve(html)}) }) // const html = await render.renderToString(); // 生成字符串 // console.log(html)})// 當(dāng)用戶訪問(wèn)一個(gè)不存在的路徑的服務(wù)端路徑 我就返回給你首頁(yè),你通過(guò)前端的js渲染的時(shí)候,會(huì)重新根據(jù)路徑渲染組件// 只要用戶刷新就會(huì)像服務(wù)器發(fā)請(qǐng)求router.get(’/(.*)’,async (ctx)=>{ console.log(’跳轉(zhuǎn)’) ctx.body = await new Promise((resolve, reject) => {render.renderToString({url:ctx.url},(err, html) => { // 通過(guò)服務(wù)端渲染 渲染后返回 if (err && err.code == 404) resolve(`not found`); console.log(html) resolve(html)}) })})// 當(dāng)客戶端發(fā)送請(qǐng)求時(shí)會(huì)先去dist目錄下查找app.use(static(path.resolve(__dirname,’dist’))); // 順序問(wèn)題app.use(router.routes());// 保證先走自己定義的路由 在找靜態(tài)文件app.listen(3000);

5.1 請(qǐng)求到localhost:3000/ 根據(jù)請(qǐng)求url參數(shù) -》 {url:ctx.url},傳給serverBundle 則 會(huì)根據(jù)服務(wù)端的打包的.js 路由系統(tǒng) 渲染出一份有該路由完整dom解構(gòu)的頁(yè)面

因?yàn)?/ 對(duì)應(yīng)的組件是Foo, 所以頁(yè)面展示Foo

vue的ssr服務(wù)端渲染示例詳解vue的ssr服務(wù)端渲染示例詳解vue的ssr服務(wù)端渲染示例詳解

網(wǎng)頁(yè)源代碼都是解析后的dom了 可以用于seo

5.2 如果請(qǐng)求了 http://localhost:3000/bar

vue的ssr服務(wù)端渲染示例詳解

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

renderToString傳入url

就會(huì)走

server-entry.js文件的默認(rèn)函數(shù) 這個(gè)js也是一個(gè)vue包含了所有客戶端原本的邏輯 只不過(guò)是放在服務(wù)端操作 。

url就是 /bar

根據(jù)路由 /bar 取出Bar組件

router跳到bar 此時(shí)頁(yè)面就會(huì)是bar組件了

同時(shí)執(zhí)行asyncData函數(shù) , 可能會(huì)改寫store或者其他數(shù)據(jù)

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

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

vue的ssr服務(wù)端渲染示例詳解

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

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

vue的ssr服務(wù)端渲染示例詳解

dist/server.html 打包后,引入了/client.bundle.js 所以要有koa-static去做靜態(tài)請(qǐng)求處理

<!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://m.propowerdrill.cn/client.bundle.js'></script></body></html>6、 部署

6.1 執(zhí)行命令 npm run run:all

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

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

vue的ssr服務(wù)端渲染示例詳解

然后把整個(gè)server.js也放在服務(wù)器

執(zhí)行node server.js 就能啟動(dòng)node服務(wù)器了

6.2 server.js里面指向的server.bundle.js和server.html指向 對(duì)應(yīng)服務(wù)器文件夾就行

vue的ssr服務(wù)端渲染示例詳解

命令解釋

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

服務(wù)端使用時(shí) ,client.bundle.js在瀏覽器使用, server.bundle.js 在服務(wù)器使用。

vue的ssr服務(wù)端渲染示例詳解

7、總結(jié)

1、SSR 首先要有個(gè)node服務(wù)器 、還有配合vue-server-renderer包使用。

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

3、創(chuàng)建server.js 集合koa或者express 做請(qǐng)求解析 然后傳入 serverBundle和template給

VueServerRenderer.createBundleRenderer函數(shù)

得到一個(gè)render

4、render.renderToString傳入請(qǐng)求的路由 比如 /bar

5、此時(shí)會(huì)進(jìn)入serverBundle默認(rèn)函數(shù)(server-entry.js打包得出的),創(chuàng)建一個(gè)vue實(shí)例app, 分析路由 vue實(shí)例然后跳轉(zhuǎn)路由,此時(shí)都是服務(wù)端的vue實(shí)例的變動(dòng)而已,還沒(méi)反應(yīng)到頁(yè)面

6、執(zhí)行對(duì)應(yīng)組件的asyncData函數(shù), 可能會(huì)改變store.state 那么在 context.state賦值就行

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

8、此時(shí)頁(yè)面拿到正常路由匹配后的dom結(jié)構(gòu)

9、html里面會(huì)有window.INITIAL_STATE={“name”:“zhufeng”} 相當(dāng)于記錄了服務(wù)端的store狀態(tài)

vue的ssr服務(wù)端渲染示例詳解

10、客戶端執(zhí)行到store時(shí) 其實(shí)沒(méi)有服務(wù)端那些改變后的狀態(tài)的 ,執(zhí)行 store.replaceState(window.INITIAL_STATE); 就能替換了服務(wù)端的狀態(tài)

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

概念圖

vue的ssr服務(wù)端渲染示例詳解

官網(wǎng):

vue-server-renderer 和 vue 必須匹配版本。 vue-server-renderer 依賴一些 Node.js 原生模塊,因此只能在 Node.js 中使用。我們可能會(huì)提供一個(gè)更簡(jiǎn)單的構(gòu)建,可以在將來(lái)在其他「JavaScript 運(yùn)行時(shí)(runtime)」運(yùn)行。 總結(jié)

到此這篇關(guān)于vue的ssr服務(wù)端渲染的文章就介紹到這了,更多相關(guān)vue ssr服務(wù)端渲染內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 无套内内射视频网站 | 一区二区免费播放 | 成年男女免费视频 | 午夜亚洲国产理论片一二三四 | 视频一区二区免费 | 又爽又黄axxx片免费观看 | 国产资源视频 | 亚洲天堂最新 | 7777久久亚洲中文字幕蜜桃 | 国产性色av免费观看 | 久久99国内精品自在现线 | 艳妇荡女欲乱双飞两中年熟妇 | 又白又嫩毛又多15p 国产热の有码热の无码视频 | av国産精品毛片一区二区三区 | 超碰在线国产97 | 日本www视频 | 51国产在线 | 久久久ww| 老司机午夜福利av无码特黄a | 国产色91| 国产精品视频一区二区三区不卡 | 精品国产一区二区三区久久影院 | 交换配乱吟粗大农村大坑性事视频 | 欧美国产激情视频 | 欧洲亚洲自拍 | 春意影院福利社 | 亚洲伊人一区 | 91精品婷婷国产综合久久蝌蚪 | 久久精品一二区 | 亚洲欧洲久久久 | 草青青视频| 国产福利在线视频 | 美女综合网 | 后进极品白嫩翘臀在线播放 | 国产精品久久久久久久久久久久久 | 老牛精品亚洲成av人片 | 曰木性按摩xxⅹxxx视频 | 涩爱av蜜臀夜夜嗨av | 色网站免费在线观看 | 自拍偷拍在线视频 | 日韩一级在线观看视频 | 无套内谢孕妇毛片免费看 | 亚洲欧洲精品成人久久曰影片 | 欧美一级在线 | 狠狠躁夜夜躁人人爽天天高潮 | 人妻内射一区二区在线视频 | 精品午夜久久 | 久久草av | 亚洲免费网站观看视频 | 国产123区在线观看 国产18精品乱码免费看 | 一本一道精品欧美中文字幕 | 1024国产视频 | 蜜桃臀无码内射一区二区三区 | 日韩精品v | 国产99在线 | 欧美 | 亚洲一区福利视频 | 超碰www| 亚洲综合一区国产精品 | 日韩看片| 亚洲国产精品福利片在线观看 | 成人av片无码免费网站 | 久热这里只有精品6 | 欧美在线成人免费 | 超碰520| 免费又黄又裸乳的视频 | 777天堂麻豆爱综合视频 | 一本色道亚洲精品aⅴ | 91操人视频| 香蕉影院在线观看 | 国产小视频免费在线观看 | 亚洲精品乱码久久久久久蜜桃不卡 | av资源部| 中文字幕乱视频 | 波多野结衣在线视频免费观看 | 国内老女人偷人av | 性欧美又大又长又硬 | 美女销魂一区二区 | 国产黑丝一区 | 国产天堂 | 亚av| 精品无码国产一区二区三区麻豆 | 国产精品白嫩极品美女视频 | 人人妻人人澡人人爽欧美一区九九 | 合欢视频污 | 久久国内视频 | 亚洲网在线观看 | 香蕉视频成人在线 | 丰满少妇高潮惨叫久久久 | 国产精品日日躁夜夜躁欧美 | 国产私密视频 | 国产真人真事毛片 | 操操干干| av之家在线| 香蕉综合网 | 中文字幕人妻第一区 | 免费一级欧美片在线播放 | 亚洲春色综合另类网蜜桃 | 少妇又色又紧又爽又刺激视频 | 夜夜爽夜夜 | 被灌满精子的少妇视频 | 大黄一级片 | 学生妹亚洲一区二区 | 91精品国产精品 | 一区二区三区四区在线观看视频 | 在线精品无码字幕无码av | 伊人久久大香线蕉成人综合网 | 少妇一级淫片免费视频 | 亚洲成av人片香蕉片 | 中文字幕被公侵犯的漂亮人妻 | 女人和拘做爰正片视频 | 欧美在线 | 亚洲 | 欧美又大粗又爽又黄大片视频 | 一区二区三区免费视频观看 | 色噜噜狠狠一区二区三区 | 精品国产a∨无码一区二区三区 | 欧洲经典二三区 | 成年人视频在线播放 | 免费网站观看www在线观 | 可以免费在线观看的av | 亚洲一区二区三区视频在线 | 又大又长又粗又爽又黄少妇视频 | а√天堂www在线天堂小说 | 日韩黄网 | 欧美激情一区二区三区视频 | 亚洲精品久久五月天堂 | 久久久精品999 | 波多野吉衣中文字幕 | 一本本月无码- | 夜夜嗨av涩爱av牛牛影视 | 亚洲国产成人片在线观看无码 | 日韩三级视频在线播放 | 成人性视频sm | 欧美三级一区二区三区 | 成人性生交视频免费看 | 精品久久久久久 | 色哟哟在线观看视频 | 毛片黄片免费看 | 黑人好猛厉害爽受不了好大撑 | 国产超碰人人做人人爱ⅴa 日韩人妻无码精品久久久不卡 | 久久久久久久av麻豆果冻 | 韩国久久久 | 精品人妻少妇嫩草av无码专区 | 精品一区二区三区免费观看 | 亚洲男人天堂2022 | 日韩av色图 | 99精品国产自在现线10页 | 日韩欧美精品在线播放 | 在线色av| 国产精品嫩草55av | 国产精品日韩专区 | 久久婷婷五月综合色和啪 | 亚洲精品国产精品99久久 | 欧美美女性生活视频 | 中文字幕一区视频 | 真实乱视频国产免费观看 | 欧美成在线视频 | 91麻豆精品一二三区在线 | av免费网 | 国产成人自拍网站 | 亚洲网站免费看 | 就操成人网 | 动漫av网站免费观看 | 日日噜噜夜夜狠狠视频 | 免费看片在线观看www | 色欲天天天综合网 | 欧美大片aaaaa免费观看 | 无套内谢少妇高潮免费 | 中文在线免费观看入口 | 91在线看黄 | 美女做爰久久久久久 | 国产偷窥网 | 婷婷色国产偷v国产偷v小说 | 国内综合精品午夜久久资源 | 国产xxxx高清在线观看 | 五月天丁香在线 | 亚洲丁香婷婷 | 国产精品xxx大片免费观看 | 中文字幕一卡二卡三卡 | 国产日韩大片 | 免费的av网址 | 特色特色大片在线 | 黄色一级视频网 | 三级a三级三级三级a十八发禁止 | 久久久久色 | 摸丰满大乳奶水www免费 | 色妞色视频一区二区三区四区 | 国产福利在线观看视频 | 欧美性开放视频 | 美女毛片网站 | 国产免费拔擦拔擦8x软件大全 | 88国产精品视频一区二区三区 | 天天天天天天干 | 久青草影院 | 暖暖日本在线观看免费 | 久草在线综合 | 国产成人精品a视频一区 | 亚洲色图插插插 | 国产爆操视频 | 中文字幕在线观看亚洲日韩 | 免费精品久久久久久久一区二区 | 国产午夜免费 | 色综合啪啪| www国产精品com| 我要看18毛片| 久久午夜鲁丝 | 日韩的一区二区 | 青草伊人久久综在合线亚洲观看 | 诱人的乳峰奶水hd | 欧美激情亚洲一区 | 欧美日韩1区 | 99久久人人爽亚洲精品美女 | 国产日本欧美一区二区 | 成人mv| 伦一理一级一a一片 | 毛茸茸性xxxx毛茸茸毛茸茸 | 亚洲熟妇少妇任你躁在线观看无码 | 国产区在线视频 | 麻豆免费在线视频 | 51区成人一码二码三码是什么 | 欧美性猛交aaaa片黑人 | 老司机在线ae85 | 五月天六月婷婷 | 国产成人免费一区二区60岁 | 99在线免费视频 | 久久精品三级视频 | 日韩高清片 | 欧美色欧美| 成人欧美一区二区三区在线 | 欧美午夜一区二区三区免费大片 | 久久深夜 | 亚洲色图欧美在线 | 亚洲狠 | 成人精品毛片va一区二区三区 | 国产91网址 | 亚洲精品91天天久久人人 | 视频在线日韩 | 亚洲毛片在线看 | 成人免费毛片东京热 | 91视频爱爱| 久久av红桃一区二区小说 | 国产精品久久久久久久久久久久午衣片 | 伊人手机视频 | 亚洲精品一区中文字幕 | 欧美性做爰猛烈叫床潮 | 亚洲最大国产成人综合网站 | 精品国产一区二区三区日日嗨 | 国产精品综合色区在线观看 | 天天摸天天舔 | 日韩三级中文字幕 | 老头糟蹋新婚少妇系列小说 | 人人澡人人妻人人爽人人蜜桃麻豆 | 美女搞黄在线观看 | 中文字幕日韩久久 | 天天躁夜夜躁av天天爽 | 极品国产在线 | 在线观看a级片 | 91久久国产自产拍夜夜嗨 | 成人久久18免费网站 | 国产精品无码av不卡 | 久草 在线| 日韩三级中文 | 国产精久久久久久妇女av | 欧美理论视频 | 国产91丝袜 | 午夜激情视频免费观看 | 亚洲国产999 | 亚洲人精品午夜射精日韩 | 日韩在线观看视频一区 | 欧美顶级metart裸体全部自慰 | 精品视频免费久久久看 | 久久精品波多野结衣 | 高清欧美精品xxxxx在线看 | 日本三级不卡 | a视频在线 | 精品国产乱码久久久久久蜜臀 | 青青操av在线 | 天天做天天爱天天爽综合网 | wwwcom黄色| 欧美日韩一区二区三区在线 | 日韩做爰视频免费 | 国产精品丝袜久久久久久消防器材 | 国产一级在线 | 狠狠综合久久久久综合网址 | 麻豆av一区二区三区久久 | 98婷婷狠狠成人免费视频 | 欧美成年人视频在线观看 | 自拍偷拍激情 | 国产一级片网址 | 美女羞羞视频网站 | 一区久久久| 九色porny丨首页入口网页 | 国产乱码精品一区二区三区四川人 | 国产日日干 | 国产精品第一页在线观看 | 黄色在线观看免费 | 婷婷91 | 国产乱码精品一品二品 | 少妇粗大进出白浆嘿嘿视频 | 黄色毛片播放 | 大陆一级a毛片杨玉环 | 久久久久人妻精品一区三寸 | 毛片大片 | 性国产xxxx乳高跟 | 久久亚洲人成网站 | 成熟丰满熟妇高潮xxxxx | 性生交大片免费全毛片 | 美女张开腿让人桶 | 久久久久国产一区二区三区 | 中文字幕视频在线观看 | 伊人色综合久久天天小片 | 亚洲国产精品久久久久久6q | 国产午夜性春猛交ⅹxxx | 亚洲熟妇色xxxxx欧美老妇y | 色一情一乱一伦一区二区三区 | 乱人伦xxxx国语对白 | 噼里啪啦完整高清观看视频 | 国产漂亮白嫩美女在线观看 | 国产99久久久欧美黑人 | 久草在线播放视频 | 一本一道久久a久久精品综合蜜臀 | 久久久精品2019免费观看 | 91丝袜一区在线观看 | 久久一区二区三区精品 | 日批视频 | 91精品国产综合久久久久久丝袜 | 激情图片区 | 日韩一区高清 | 无码人妻精品一区二区三区东京热 | 人善性zzzzzo另类 | 国产精品蜜臀av免费观看四虎 | 男人的天堂99| 亚洲色播爱爱爱爱爱爱爱 | 免费毛片小视频 | 色诱久久av | 综合国产一区 | 午夜性视频国产牛牛视频 | 奇米777四色在线精品 | 国产素人在线 | 欧美激情一区二区 | 免费专区丝袜调教视频 | 精品999久久久 | 亚洲精品高清国产一久久 | 久久黄色一级片 | 中文毛片 | 久久综合久久美利坚合众国 | 岛国av一区 | 老湿影院av | 天堂激情网 | 在线观看v片| 国产热99| 国产日韩欧美中文 | 在线免费看a | 久久中文字幕人妻熟av女蜜柚m | 亚洲欧美日韩精品色xxx | 欧美精品亚洲精品日韩精品 | 欧美日韩国产精品一区 | 少妇和小鲜肉高潮毛片 | 日本一区二区视频在线 | 69堂国产成人免费视频 | 伊人9| 福利毛片| 国产精品女人特黄av片 | 欧洲精品99毛片免费高清观看 | 亚洲自偷自偷在线成人网站传媒 | www国产精品内射熟女 | 极品美女极度色诱视频在线 | 国产成人免费观看 | 在线观看黄av| www夜夜骑| 天堂在/线中文在线资源 官网 | 久久久精品欧美一区二区免费 | 欧日韩在线观看 | 国产精品一二三区在线观看 | 国产91av在线 | 国产精品久久久久aaaa | 瑜伽美女健身视频集锦 | 久久久久成人片免费观看蜜芽 | 一本久久综合亚洲鲁鲁五月天 | 国产精品一品二区三区的使用体验 | 国产又爽又黄又无遮挡的激情视频 | 亚洲国产精品激情在线观看 | 日本少妇aaa | 日本视频色 | 九九九九热精品免费视频点播观看 | 天天色天天爱 | 九草在线| 精品国产乱码久久久久久虫虫 | 久久久三级 | 色综合社区 | 无遮挡呻吟娇喘视频免费播放 | 男人午夜免费视频 | 成人看的视频 | yw在线观看 | 国产福利第一页 | 成人学院中文字幕 | 最近最新中文字幕高清免费 | 精品国产精品亚洲一本大道 | 黑人干日本少妇 | 91亚洲精华国产精华液 | 欧美经典影片视频中文 | 久久夜精 | 国产成年人视频 | av青草| 男人的天堂毛片 | 成人免费黄色 | 涩涩一区| 538精品一线 | 91久久国产露脸精品国产 | 男人天堂视频在线 | 成人午夜性 | 深夜久久| 四虎成人精品国产永久免费无码 | 五月天免费网站 | 蜜桃av噜噜一区二区三区小说 | 国产精品免费看久久久无码 | 亚洲一区二区色 | 黄色三级情侣片 | 久久99国产综合精品 | 黄色片在线免费 | 国产精品美女www爽爽爽动态图 | 干片网在线观看 | 日韩毛片大全 | 国产一级二级在线观看 | 亚洲男人天堂2019 | 久久久精品人妻无码专区不卡 | 少妇学院在线观看 | 国产高清性xxxxxxxx | 狠狠干夜夜 | 亚洲精品66 | 国产奶水涨喷在线播放 | 成人一级视频 | 国产精品久久久久久福利 | 波多野结衣视频网站 | 91黄色免费看 | 中文字幕一区二区三区精品 | 色噜噜狠狠色综合中文字幕 | 青娱乐青青草 | 欧美人做人爱a全程免费 | 美女黄色真播 | 亚洲一卡二卡三卡四卡 | 日韩极品视频 | 香蕉av777xxx色综合一区 | 成人精品一区二区三区网站 | 久久精品久久久久久 | 美女又爽又黄视频毛茸茸 | 久久精品99久久 | 国产精品久久久久久吹潮 | 久久免费看少妇高潮a | 亚洲乱码国产一区三区 | 在线观看国产视频 | 亚洲私拍 | 激情久| 毛片毛片毛片毛片毛片毛片毛片毛片 | 国产丰满老熟女重口对白 | 国产午夜精品18久久蜜臀董小宛 | 欧美刺激性大交 | 女仆裸体打屁屁羞羞免费 | 亚洲国产欧美日韩在线观看第一页 | 日韩激情第一页 | 亚洲国产精品久久久天堂不卡 | av怡红院一区二区三区 | 风韵少妇spa私密视频 | 91精选国产 | 亚洲国产制服丝袜先锋 | 中文字幕第十二页 | 她也色在线观看 | 亚洲免费激情视频 | 国产欧美一区二区精品久导航 | 欧洲grand老妇人bbw | 伊甸园成人入口 | 国产人人射 | 嫩草影院一区二区 | 欧美a级成人淫片免费看 | 国产精品人妻一区夜夜爱 | 特黄三级男人添女人下面 | 亚洲精品久久久久久久久久 | 免费一级a毛片夜夜看 | 成人高潮片免费视频欧美 | 激情第一区仑乱 | 熟妇人妻中文av无码 | 五月色婷 | 午夜精品久久久久久久96蜜桃 | 爱爱视频免费看 | 伊人热久久| 简单av在线 | 亚洲欧美久久 | 欧美国产亚洲精品suv | 色婷婷激情av | 性一交一乱一乱一视频 | 羞羞动漫在线看免费 | 日本丰满大乳奶做爰 | 天堂乱码一二三区 | 欧美综合国产精品久久丁香 | 亚洲不卡中文字幕 | 国产目拍亚洲精品99久久精品 | 美女18免费视频 | 999国产精品 | 淫欲的代价k8经典网 | 色天天色| 免费无码肉片在线观看 | 成人国产一区二区三区精品 | 大肉大捧一进一出好爽视频mba | 免费黄色成人 | 亚洲欧美日韩第一页 | 五月婷婷久 | 国模吧无码一区二区三区 | 日韩毛片免费无码无毒视频观看 | 网友自拍区视频精品 | 三级在线视频 | 黑人插少妇| 亚洲精品aaa | 亚洲精品一区 | 亚洲欧洲无码一区二区三区 | 熟女人妻av五十路六十路 | 亚洲淫欲| 国产av无码专区亚洲版综合 | 麻豆国产人妻欲求不满谁演的 | 精品国产一区二区三区久久 | 亚洲欧美另类一区 | 国产淫 | 九九热在线免费视频 | 亚洲另类调教 | 欧美性视频网站 | 欧美日韩色综合 | 91香蕉黄| 国产成人无码视频一区二区三区 | 免费麻豆av | 涩涩网址| 日本一卡二卡四卡无卡乱码视频免费 | 久久99精品久久久久久琪琪 | 国产亚洲va综合人人澡精品 | 自拍偷自拍亚洲精品播放 | 成码无人av片在线观看网站 | 97精品在线视频 | 狠狠噜天天噜日日噜 | 欧美一区二区三区成人 | 人人做人人爱人人爽 | 她也啪在线视频 | 欧美国产日韩在线观看 | 91精品亚洲影视在线观看 | 精品国产三级a∨在线观看 无码丰满熟妇 | 中文字幕91视频 | 波多野结衣在线观看一区二区三区 | 美女高潮视频在线观看 | 午夜福利理论片高清在线 | 人妻丰满熟妇av无码区免 | 国产91精品一区二区 | 九九久久久久 | 日韩色吧 | 丰满爆乳一区二区三区 | 精品国产aⅴ无码一区二区 亚洲人成人无码网www国产 | 久久网免费视频 | 亚洲男女内射在线播放 | 久久视了 | 国产在线黄色 | 99精品一区二区 | 国产国拍精品亚洲 | 色天天综合网 | 日本亚洲欧洲色α | 一区三区视频 | 亚洲欧美精品综合在线观看 | 久夜精品 | 国产偷国产偷亚洲高清人 | 一级性生活大片 | 噼里啪啦动漫高清在线观看 | 国产精品久久久久久久av | 伊人久久麻豆 | 中文字幕在线精品 | 成人在线观看你懂的 | 国产免费啪啪 | 美女网站免费视频 | 国产美女一区 | 国产亚洲精品久久久久久无几年桃 | 天堂在线中文网www 亚洲中文字幕在线第六区 日本高清不卡aⅴ免费网站 | 在线中出| 九九九视频在线观看 | 一级做a爰片性色毛片99 | 久久97精品 | 亚洲国产图片 | 全部毛片永久免费看 | 天天干网址 | 男女黄色毛片 | 欧美大片在线播放 | 日产亚洲一区二区三区 | 精品91av | 真实的国产乱ⅹxxx66小说 | 黄色网址在线视频 | 夜夜影院未满十八勿进 | 国产在线精品一区二区三区不卡 | 亚洲午夜剧场 | 日本高清视频wwww色 | 亚洲午夜精品久久久久久浪潮 | 成人av中文解说水果派 | 成人18网站 | 亚洲日韩av无码 | 国产成人无码综合亚洲日韩 | 国产免费一级视频 | 亚洲女优在线 | 亚洲精品久久7777777 | 成人国内精品久久久久影院成.人国产9 | 中国香蕉视频 | 99er久久| 法国极品成人h版 | 中文字幕在线不卡视频 | 91视频久久久久久 | 亚洲 欧美 偷自乱 图片 | 丁香综合网 | 黄页网站视频免费大全 | 风韵少妇性饥渴推油按摩视频 | 18禁无遮挡羞羞污污污污免费 | 欧美激情一区二区三区蜜桃视频 | 色爽 av| 国产a黄| 亚洲 小说 欧美 激情 另类 | 都市激情自拍偷拍 |