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

Vue服務(wù)器端渲染nuxt.js初探

開發(fā) 前端
前端vue項(xiàng)目, 需要將新增的幾個(gè)路由頁面做seo處理。在調(diào)研 插件 prerender-spa-plugin后,發(fā)現(xiàn)無法滿足 vuex 以及 plugins 等要求時(shí),果斷選用了 nuxt.js做服務(wù)器渲染。

開頭還是來一段廢話: 年關(guān)將近,給大家拜個(gè)早年,愿大家年會(huì)都能抽大獎(jiǎng),來年行大運(yùn)。

廢話不多說,直接進(jìn)正文。

項(xiàng)目環(huán)境:

前端vue項(xiàng)目, 需要將新增的幾個(gè)路由頁面做seo處理。

在調(diào)研 插件 prerender-spa-plugin后,發(fā)現(xiàn)無法滿足 vuex 以及 plugins 等要求時(shí),果斷選用了 nuxt.js做服務(wù)器渲染。

下面是在項(xiàng)目中整理的 文檔 和 問題

nuxt.js 是一個(gè)基于 Vue.js 的通用應(yīng)用框架

它預(yù)設(shè)了利用 Vue.js 開發(fā) 服務(wù)端渲染(SSR, Server Side Render) 的應(yīng)用所需要的各種配置,同時(shí)也可以一鍵生成靜態(tài)站點(diǎn)。

值得一提的是,nuxt是基于node.js的,后端如果是其他語言時(shí),是否考慮到再加一層node.js的合理性。

鏈接地址: https://zh.nuxtjs.org/guide/installation

利用npx腳手架創(chuàng)建項(xiàng)目

鏈接地址: https://zh.nuxtjs.org/guide/installation

會(huì)提供以下選項(xiàng)

1. 在集成的服務(wù)器端框架之間進(jìn)行選擇: Express / Koa ...

2. 選擇您喜歡的UI框架: Bootstrap / Element UI ...

3. 選擇你想要的Nuxt模式 (Universal or SPA) 普通類型 / 單頁應(yīng)用

4. 添加 axios module 以輕松地將HTTP請(qǐng)求發(fā)送到您的應(yīng)用程序中。

5. 添加 EsLint 以在保存時(shí)代碼規(guī)范和錯(cuò)誤檢查您的代碼。

6. 添加 Prettier 以在保存時(shí)格式化/美化您的代碼。

注意:

1. 如果項(xiàng)目自帶分支等git信息時(shí), 需要將npx生產(chǎn)的目錄里面隱藏的git 文件刪除

因?yàn)閚px生成文件時(shí),默認(rèn)為master 分支,類似于 gitmodule 子分支性質(zhì)

2. 其中第3點(diǎn),選擇 Universal 時(shí) 才會(huì)默認(rèn)輸出靜態(tài)頁,也就是能夠seo的,當(dāng)選擇spa時(shí),則無法seo

可修改 nuxt.config.js 中的配置項(xiàng) mode: 'Universal' 來定義類型

啟動(dòng)項(xiàng)目

命令: npm run dev 默認(rèn)命令

這時(shí)會(huì)報(bào)錯(cuò),說未指定ip 什么的,需配置項(xiàng):

nuxt.config.js 中:

  1. server: {  
  2. // port: '3000', // 定義 輸出端口 ,默認(rèn)為3000  
  3. host:'0.0.0.0' // 定義 輸出 ip  
  4. },  

注意:

在server 目錄中國(guó)的index.js中 會(huì)讀取 nuxt.config.js 中的配置項(xiàng),當(dāng)不存在時(shí)會(huì)賦值默認(rèn)值 

  1. const {  
  2. host = process.env.HOST || '127.0.0.1' 
  3. port = process.env.PORT || 3000 // 默認(rèn)配置條件下,修改此處無效 仍舊為3000端口  
  4. } = nuxt.options.server  

頁面上的注意點(diǎn)有:

css 都默認(rèn)加載到 頁面上了;

處理方式有2種:

1. 在 nuxt.config.js 文件 header 配置 link 外鏈這些公共樣式 (下面有具體說明)

2. 在 nuxt.config.js 文件 build 配置 中 自定義文件路徑 以及hash值 (下面有具體說明)

項(xiàng)目目錄結(jié)構(gòu)

1. 資源目錄 (assets)

用于組織未編譯的靜態(tài)資源如 LESS、SASS 或 JavaScript。

2. 組件目錄 (components)

用于組織應(yīng)用的 Vue.js 組件。Nuxt.js 不會(huì)擴(kuò)展增強(qiáng)該目錄下 Vue.js 組件,

即這些組件不會(huì)像頁面組件那樣有 asyncData 方法的特性。

3. 布局目錄 (layouts) 該目錄名為Nuxt.js保留的,不可更改。

用于組織應(yīng)用的布局組件。

4. 中間件目錄 (middleware)

目錄用于存放應(yīng)用的中間件

文件名的名稱將成為中間件名稱(middleware/auth.js將成為 auth 中間件)。

一個(gè)中間件接收 context 作為第一個(gè)參數(shù):

具體參考: https://zh.nuxtjs.org/guide/routing#中間件

5. 頁面目錄 (page) 該目錄名為Nuxt.js保留的,不可更改。

用于組織應(yīng)用的路由及視圖。Nuxt.js 框架讀取該目錄下所有的 .vue 文件并自動(dòng)生成對(duì)應(yīng)的路由配置。

nuxt 會(huì)根據(jù)文件夾名稱以及目錄結(jié)構(gòu)動(dòng)態(tài)生產(chǎn) router, 無需額外配置。

6. 靜態(tài)文件目錄 (static)

用于存放應(yīng)用的靜態(tài)文件,此類文件不會(huì)被 Nuxt.js 調(diào)用 Webpack 進(jìn)行構(gòu)建編譯處理。

服務(wù)器啟動(dòng)的時(shí)候,該目錄下的文件會(huì)映射至應(yīng)用的根路徑 / 下。

一般用于 放置公共css,以及 js 文件, 但是如果不想這些css和js走根目錄的話,

需要將這些css放置到 assets中,然后在 nuxt.config.js中 配置 build 選項(xiàng) 下面會(huì)具體說明

7. Store 目錄

用于組織應(yīng)用的 Vuex 狀態(tài)樹 文件

注意: 普通的spa 項(xiàng)目中拋出一個(gè)實(shí)例對(duì)象即可, store為:

  1. export default new Vuex.Store({  
  2. actions,  
  3. getters,  
  4. })  

這里則需要拋出一個(gè) 實(shí)例函數(shù)對(duì)象:

  1. const store = () => {  
  2. return new Vuex.Store({  
  3. state,  
  4. getters,  
  5. mutations,  
  6. actions  
  7. })  
  8.  
  9. export default store  

8. nuxt.config.js

用于組織Nuxt.js 應(yīng)用的個(gè)性化配置,以便覆蓋默認(rèn)配置。

9. package.json

省略...

別名

~ 或 @ // src目錄

~~ 或 @@ // 根目錄

默認(rèn)情況下,src目錄和根目錄相同

頁面間路由的跳轉(zhuǎn)

要在頁面之間使用路由,建議使用 標(biāo)簽。

js 中仍然可以使用 $router.push 等方法。

路由跳轉(zhuǎn)時(shí)的頁面間過渡效果

Nuxt.js 默認(rèn)使用的過渡效果名稱為 page。

需要在 assets/目錄下創(chuàng)建 main.css 添加全局樣式。

  1. .page-enter-active, .page-leave-active {  
  2. transition: opacity .5s;  
  3.  
  4. .page-enter, .page-leave-active {  
  5. opacity: 0;  
  6.  

然后添加到 nuxt.config.js 文件中: 

  1. module.exports = {  
  2. css: [  
  3. 'assets/main.css'  
  4. ],  
  5. loading: { color: '#2152F3' },  
  6.  

更多過渡效果: https://zh.nuxtjs.org/guide/routing#過渡動(dòng)效

頭部信息 (Meta 標(biāo)簽 ,全局樣式)

nuxt.config.js 里定義應(yīng)用所需的所有默認(rèn) meta 標(biāo)簽 

  1. head: {  
  2. meta: [  
  3. { charset: 'utf-8' },  
  4. name'viewport', content: 'width=device-width, initial-scale=1' }  
  5. { hid: 'description'name'description', content: '' }  
  6. ],  
  7. link: [ // 這里可以引用全局的樣式,但是會(huì)默認(rèn)走根目錄  
  8. { rel: 'stylesheet', href: 'https://fonts.googleapis.com/css?family=Roboto' }  
  9. { rel: 'stylesheet', href: '~/static/common.js' } // 文件一般都放在static目錄下  
  10.  
  11.  

具體參考:https://zh.nuxtjs.org/api/configuration-head

異步數(shù)據(jù) (asyncData方法,限于page頁面組件,components中不適用)

這里包括 asyncData鉤子 / fetch 鉤子 / 。。。

【fetch】 用于在渲染頁面前填充應(yīng)用的狀態(tài)樹(store)數(shù)據(jù), 與 asyncData 方法類似,不同的是它不會(huì)設(shè)置組件的數(shù)據(jù)

【asyncData】 主要用于請(qǐng)求ajax 填充data中的數(shù)據(jù)

每次加載之前被調(diào)用。它可以在服務(wù)端或路由更新之前被調(diào)用。 

  1. asyncData ({ params }) {  
  2. return axios.get(`https://my-api/posts/${params.id}`) 
  3. .then((res) => {  
  4. // 賦值給頁面 data中的數(shù)據(jù)  
  5. return { title: res.data.title }  
  6. })  
  7.  

或者變換為同步請(qǐng)求:

  1. async asyncData() {  
  2. let formData = {}  
  3. let ajaxData = await axios({  
  4. method: "post" 
  5. url: url,  
  6. data: qs.stringify(formData),  
  7. retryDelay : 1000,  
  8. withCredentials : true 
  9. responseType : 'json' 
  10. timeout : 60000,  
  11. 'Content-Type' : 'application/x-www-form-urlencoded'  
  12. })  
  13.  

注意添加 catch

注意:

這個(gè)異步請(qǐng)求函數(shù), 第一次執(zhí)行環(huán)境為node環(huán)境中,也就是服務(wù)器端,后續(xù)刷新頁面則執(zhí)行環(huán)境為client 客戶端

本地開發(fā)時(shí),如果在客戶端直接請(qǐng)求完整路徑時(shí)會(huì)經(jīng)常遇到跨域問題,所以需要在 asyncData 中區(qū)分環(huán)境變量

process.env.VUE_ENV 區(qū)分 是server 還是 client

然后根據(jù)不同的環(huán)境配置不同的 url , 并且在 client時(shí), 需要做服務(wù)器端代理請(qǐng)求,需要給url增加一層代理標(biāo)識(shí)

例如:client環(huán)境中 

  1. url = '/api' + '/get-user-info' 
  2. nuxt.config.js 中  
  3. /*  
  4. ** 處理代理跨域問題  
  5. */  
  6. axios: {  
  7. proxy: true 
  8. prefix: '/api', // 增加請(qǐng)求標(biāo)識(shí)  
  9. credentials: true 
  10. },  
  11. proxy: {  
  12. '/api': {  
  13. // 代理地址  
  14. target: (process.env.NODE_ENV == 'production') ?'http://test.' : 'http://www.' ,  
  15. changeOrigin: true 
  16. pathRewrite: {  
  17. '^/api''' // 將標(biāo)識(shí) 替換為 ‘’  
  18. },  
  19. },  
  20.  

錯(cuò)誤處理 :

context中提供了一個(gè) error(params) 方法,你可以通過調(diào)用該方法來顯示錯(cuò)誤信息頁面。

params.statusCode 可用于指定服務(wù)端返回的請(qǐng)求狀態(tài)碼。 

  1. asyncData ({ params, error }) {  
  2. return axios.get(`https://my-api/posts/${params.id}`)  
  3. .then((res) => {  
  4. return { title: res.data.title }  
  5. })  
  6. .catch((e) => {  
  7. error({ statusCode: 404, message: 'Post not found' })  
  8. })  
  9.  

第三方插件的使用

例如:element-ui

需要在 plugins/ 中 添加 element-ui.js 

  1. import Vue from 'vue'  
  2. import Element from 'element-ui/lib/element-ui.common'  
  3. import locale from 'element-ui/lib/locale/lang/en'  
  4. export default () => {  
  5. Vue.use(Element, { locale })  
  6.  

在 uuxt.config.js 中 

  1. plugins: [  
  2. "~/plugins/element-ui" 
  3. // {src : '~/plugins/ga.js' , ssr : false} 是否做ssr處理, false時(shí)為在客戶端才加載  
  4. ],  

這樣全局就可以使用了

注意:

在使用第三方插件時(shí)需要注意 插件內(nèi)部很多地方都會(huì)用到window對(duì)象,在服務(wù)端會(huì)報(bào)錯(cuò),所以需要將ssr設(shè)置為false

在生產(chǎn)環(huán)境中, 有一些插件,在多個(gè)頁面中引用,這樣會(huì)造成多次加載打包的現(xiàn)象

所以: 在 build配置項(xiàng)中增加配置 

  1. build: {  
  2. vendor:['axios''qs'], // 防止多次打包  
  3.  

page 函數(shù)鉤子生命周期 以及window 對(duì)象

經(jīng)常會(huì)在 第三方組件或者調(diào)用的時(shí)候 遇到window對(duì)象報(bào)錯(cuò)問題。

  1. asyncData() {  
  2. console.log(window) // 服務(wù)端報(bào)錯(cuò)  
  3. console.log(this) // undefined  
  4. },  
  5. fetch() {  
  6. console.log(window) // 服務(wù)端報(bào)錯(cuò)  
  7. },  
  8. created () {  
  9. console.log(window) // undefined  
  10. },  
  11. mounted () {  
  12. console.log(window) // Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, frames: Window, …}  
  13.  

css js 文件打包文件夾處理

在 uuxt.config.js 中,只需配置生產(chǎn)環(huán)境中。

  1. build: {  
  2. extractCSS: { allChunks: true }, // css 獨(dú)立打包 link 的形式加載  
  3. publicPath: '/sample/assets/', //sample/essays 打包的默認(rèn)路徑為 ‘_nuxt’ 或者可以指定cdn 域名  
  4. filenames:{ // css 和 js img 打包時(shí)指定文件夾  
  5. app: ({ isDev }) => isDev ? '[name].js' : '[chunkhash].js' 
  6. chunk: ({ isDev }) => isDev ? '[name].js' : '[chunkhash].js' 
  7. css: ({ isDev }) => isDev ? '[name].js' : '[contenthash].css' 
  8. img: ({ isDev }) => isDev ? '[path][name].[ext]' : '[hash:7].[ext]'  
  9.  
  10. },  

輸出 css link 路徑: /sample/essays/[contenthash].css

注意: 靜態(tài)資源文件路徑名 不能和頁面路由名稱相同 publicPath 默認(rèn)配置 '/' 無效

部署

先 npm run build 打包 client文件和 server 文件。

然后 npm runb start 啟動(dòng)服務(wù)器。

pm2 管理:

  1. pm2 start npm --name "my-nuxt" -- run start 

部署時(shí) 需要注意 如果是 從其他地方重定向 到 nuxt 環(huán)境中的頁面是, 需要額外配置一個(gè) css / js 重定向路由,并且需要注意 header頭部信息,防止出現(xiàn) css 文件返回頭部信息為 Content-Type text/plain。

目前項(xiàng)目中只運(yùn)用到這么多,后續(xù)項(xiàng)目遷移時(shí)遇到更多的問題會(huì)做補(bǔ)充,如果大家遇到過其他的坑點(diǎn)可以在下面評(píng)論中總結(jié)出來以及解決方案。

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2020-04-14 12:53:01

Nuxt.jsVue.js前端

2021-04-30 09:32:38

服務(wù)端渲染SSR

2023-07-26 10:21:26

服務(wù)端組件客戶端

2024-02-22 13:47:40

2009-02-16 16:30:23

OperaTurbo服務(wù)器

2023-01-26 00:56:41

Nuxt.js存儲(chǔ)庫(kù)開發(fā)

2023-06-14 20:58:05

2023-08-24 16:54:05

2011-07-26 11:07:08

JavaScript

2021-09-02 10:49:25

Node.jsPHP服務(wù)器開發(fā)

2012-10-15 13:40:15

IBMdw

2014-01-15 10:06:30

vFlash

2011-09-08 10:21:50

Node.js

2014-11-14 11:03:56

微軟.NET

2023-06-30 08:00:00

漏洞網(wǎng)絡(luò)安全SSTI

2017-12-06 22:29:53

2015-11-04 14:14:56

HTTP網(wǎng)絡(luò)協(xié)議

2011-06-07 16:01:46

Android 服務(wù)器 數(shù)據(jù)交互

2013-12-25 11:01:16

JavaScript

2021-07-27 06:14:32

服務(wù)器端移動(dòng)端性能測(cè)試
點(diǎn)贊
收藏

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

精品国产鲁一鲁一区二区张丽 | 日韩欧美一级二级三级| 免费国产成人看片在线| 全国男人的天堂网| 日韩和欧美一区二区三区| 亚洲人成网站免费播放| 欧美大片久久久| 成人性生交大片免费看在线播放| 91麻豆视频网站| 国产日韩欧美电影在线观看| 久久网一区二区| 国产亚洲第一伦理第一区| 91精品国产91热久久久做人人 | 国产日韩精品久久| 在线观看亚洲黄色| 欧美日韩国产精品一区二区亚洲| 国产丝袜一区二区三区免费视频| а 天堂 在线| 厕沟全景美女厕沟精品| 亚洲欧美激情视频在线观看一区二区三区| 国产一区二区三区色淫影院| 老熟妇一区二区三区啪啪| 黄色成人精品网站| 三级精品视频久久久久| 国产精品无码在线| 秋霞一区二区| 欧美性生活大片视频| 欧美一级欧美一级| 大片免费在线看视频| 国产视频一区在线播放| 国产精品一区二区三区四区五区 | www.黄色在线| 国产精品videossex| 欧美精品成人一区二区三区四区| 久久婷婷国产精品| 阿v视频在线观看| 亚洲精品福利视频网站| 亚洲精品视频一二三| 涩爱av在线播放一区二区| 国产精品资源在线观看| 国产精品直播网红| 中文在线观看av| 久久精品中文| 奇米四色中文综合久久| 国产精品美女毛片真酒店| 牛牛国产精品| 久久综合免费视频影院| 来吧亚洲综合网| 不卡中文字幕| 亚洲性无码av在线| 亚洲成人网在线播放| 日本成人7777| 亚洲成人激情在线观看| 国产精品成人在线观看| 国产成人小视频在线观看| 日韩精品久久久久久久| 国产精品v日韩精品v欧美精品网站| 色阁综合伊人av| 欧美xxxx精品| 色婷婷热久久| 日韩中文av在线| 国产成人在线网址| 日韩在线观看| 日韩中文字幕欧美| 天天看天天摸天天操| 亚洲成人最新网站| 超碰91人人草人人干| 美女福利视频在线观看| 黑丝一区二区三区| 2021久久精品国产99国产精品| 日韩熟女精品一区二区三区| 国产欧美短视频| 日韩av电影院| 最新在线中文字幕| 久久国产夜色精品鲁鲁99| 成人免费高清完整版在线观看| 国产男男gay体育生网站| 国产伦精品一区二区三区视频青涩 | 欧美一区免费| 国内精品免费午夜毛片| 中文字幕精品三级久久久| 久久天堂精品| 国产日韩在线视频| 国产精品成人无码| 国产自产高清不卡| 精品在线视频一区二区| 免费在线一级视频| 中文字幕第一区综合| dy888午夜| 激情国产在线| 欧美三级视频在线观看| 日本中文字幕有码| 精品一区亚洲| 久久中文字幕在线视频| 可以免费在线观看的av| 久久国产婷婷国产香蕉| 国产精品一区视频网站| 国产在线一二| 一区二区三区日韩欧美精品 | 国产不卡123| 欧美伊人久久久久久久久影院| 成人免费黄色av| 四虎影视精品| 麻豆国产va免费精品高清在线| 日韩欧美中文字幕一区二区| 美女视频网站黄色亚洲| 韩国一区二区三区美女美女秀| 高清毛片在线看| 亚洲国产一区视频| 亚洲欧美自拍另类日韩| 久久国产精品免费精品3p| 最近2019年中文视频免费在线观看| 久久在线视频精品| 日本 国产 欧美色综合| 国产精品综合久久久久久| √新版天堂资源在线资源| 亚洲午夜免费视频| 中文av一区二区三区| 美国成人xxx| 九九热这里只有精品免费看| 男人天堂视频在线| 99久久精品久久久久久清纯| 在线观看成人av电影| 美女福利一区二区| 欧美精品一区二区高清在线观看 | 亚洲一区二区三区国产| 成人精品视频一区二区| 精品成人自拍视频| 欧美成人在线网站| 亚洲午夜精品久久久| 久久免费午夜影院| 欧美精品久久久久久久免费| 日韩精品亚洲专区在线观看| 中文字幕亚洲综合久久| 欧产日产国产69| 91香蕉视频在线| 男的插女的下面视频| 中文字幕综合| 日韩中文字幕国产| 中文字幕日韩经典| 亚洲国产岛国毛片在线| 黄色av免费在线播放| 欧美日韩导航| 777精品视频| 刘玥91精选国产在线观看| 亚洲欧美另类久久久精品2019| 香蕉视频网站入口| 欧美精品系列| 国产精品女人久久久久久| 国产福利电影在线| 欧洲激情一区二区| 国产综合精品久久久久成人av| 久久精选视频| 日本欧美色综合网站免费| 电影网一区二区| 亚洲免费一级电影| 中文在线第一页| 久久久久国产免费免费| 久久无码高潮喷水| 激情五月色综合国产精品| 日韩av免费在线| 国家队第一季免费高清在线观看| 91极品视觉盛宴| youjizz亚洲女人| 美腿丝袜在线亚洲一区| 在线亚洲美日韩| 国产日韩欧美中文在线| 欧美第一黄色网| 天堂av资源网| 在线观看一区二区视频| 91香蕉国产视频| 国产一区二区不卡| 日本福利视频一区| 亚洲+小说+欧美+激情+另类 | 成人免费看片视频在线观看| 88久久精品| 欧美在线免费观看| 成人免费在线视频网| 欧美日韩视频在线观看一区二区三区| 成人做爰视频网站| 成人免费视频视频在线观看免费 | 国产美女高潮在线观看| 国产丝袜一区视频在线观看| 中文字幕丰满人伦在线| 亚洲免费av高清| 人妻无码中文久久久久专区| 丝袜亚洲精品中文字幕一区| 成年人黄色在线观看| 99亚洲乱人伦aⅴ精品| 日韩av成人在线观看| 久久综合之合合综合久久| 亚洲精品一区二区三区蜜桃下载 | 欧美日免费三级在线| 久久久久无码国产精品| 久久免费精品国产久精品久久久久| 中文字幕av不卡在线| 91久久亚洲| 一区二区日本伦理| 国产精品玖玖玖在线资源| 国产精品美女主播| bl视频在线免费观看| 夜夜嗨av色一区二区不卡| 成人1区2区3区| 欧美色偷偷大香| 国产大片中文字幕| 国产精品网站在线| 星空大象在线观看免费播放| 久久精品国产精品亚洲精品| 国自产拍偷拍精品啪啪一区二区| 久久精品国产www456c0m| 国产无套精品一区二区| 成人精品在线| 国产成人精品日本亚洲专区61 | 欧美性受xxx| www.在线视频| 国产亚洲精品久久久久久| 蜜桃视频在线观看www| 欧美日韩亚洲另类| 欧美精品二区三区| 一区二区三区在线观看国产| 中文天堂资源在线| 99久久精品国产观看| 一本之道在线视频| 美女视频黄 久久| 国产男女在线观看| 精品99视频| www国产无套内射com| 不卡中文字幕| 色噜噜一区二区| 牲欧美videos精品| 国产一区二区免费在线观看| 国产精品亚洲四区在线观看| 国产精品免费久久久久影院| 欧美天堂视频| 国产91色在线| 精品国产免费人成网站| 91精品国产成人| xxx性欧美| 欧美激情亚洲另类| 中文av资源在线| 美乳少妇欧美精品| 国产在线观看av| 日韩综合中文字幕| 青青青青在线| 久久久精品影院| 黄色精品免费看| 日韩视频免费观看| 欧美一区二区三区| zzjj国产精品一区二区| 成年人在线看| 中日韩美女免费视频网站在线观看 | 国产一区二区0| 999热精品视频| 国产乱人伦偷精品视频不卡| 毛片毛片毛片毛片毛| 国产传媒日韩欧美成人| 制服.丝袜.亚洲.中文.综合懂| 国产高清不卡二三区| 国产性猛交96| 99久久久国产精品免费蜜臀| 网站免费在线观看| 久久久亚洲精品石原莉奈| 欧美激情亚洲色图| 中文字幕在线观看一区| 精品爆乳一区二区三区无码av| 一区二区三区成人在线视频| 国产一级av毛片| 精品久久香蕉国产线看观看亚洲 | 日本孕妇大胆孕交无码| 欧美激情伊人电影| 国产美女精品写真福利视频| 国产成人+综合亚洲+天堂| 日本精品在线一区| 91精品中文在线| 超碰精品在线| 欧美日韩中文国产一区发布| sdde在线播放一区二区| 三年中文高清在线观看第6集| 欧美久久影院| 日韩a在线播放| 久久成人综合网| 亚洲精品久久一区二区三区777| 不卡视频在线观看| 少妇无套高潮一二三区| 亚洲欧美日韩中文字幕一区二区三区| 久久久久久久9999| 一本色道a无线码一区v| 国产又粗又黄视频| 亚洲国产精品久久精品怡红院 | 久久视频在线播放| 96av在线| 国产精品亚洲激情| 粉嫩的18在线观看极品精品| 日本一区二区三区四区在线观看 | 大西瓜av在线| 视频一区国产视频| 性生交大片免费看l| 久久久久久久久久久久久久久99| 亚洲女人毛茸茸高潮| 午夜欧美大尺度福利影院在线看| 香蕉污视频在线观看| 日韩一区二区中文字幕| 你懂的在线视频| 欧美大奶子在线| jizz内谢中国亚洲jizz| 91久久国产精品91久久性色| 亚洲国产最新| 黄网站色视频免费观看| 日韩1区2区3区| 白丝校花扒腿让我c| 国产女人18毛片水真多成人如厕| 国产亚洲色婷婷久久99精品| 欧美日韩国产综合一区二区 | 欧美另类一区二区| 欧美一级片免费看| 毛片网站在线| 久久久日本电影| 91九色成人| 四虎永久国产精品| 在线亚洲激情| 手机在线观看日韩av| 欧美激情一区在线观看| 国产精品一区二区6| 欧美成人性福生活免费看| 岛国在线大片| 日本精品久久电影| 粉嫩av一区二区| 蜜臀在线免费观看| 久久精品国产网站| 丰满的亚洲女人毛茸茸| 欧美视频专区一二在线观看| 欧美熟妇交换久久久久久分类| 久久综合电影一区| 久久久国产精品网站| 欧美日韩一区在线视频| 国产欧美三级| 亚洲男人在线天堂| 亚洲va韩国va欧美va精品| 精品国产免费无码久久久| 久久这里有精品| 91精品一久久香蕉国产线看观看| 亚洲国产另类久久久精品极度| 日韩中文字幕一区二区三区| 国产黄色三级网站| 亚洲大尺度视频在线观看| 亚洲毛片欧洲毛片国产一品色| 欧美猛交ⅹxxx乱大交视频| 国产剧情一区二区在线观看| 精品日韩在线播放| 国产精品一区二区果冻传媒| 日韩黄色免费观看| 日韩精品在线网站| 黑人玩欧美人三根一起进| 国产精品手机视频| 亚洲人成在线影院| 丰满大乳奶做爰ⅹxx视频| 欧美日韩在线第一页| 黄网站在线观看| 国产精品久久久久久久久免费| 成人久久综合| 91精品999| 一区二区欧美精品| 少妇精品高潮欲妇又嫩中文字幕| 性欧美xxxx| 九九久久婷婷| 性生活免费在线观看| 日韩一区在线免费观看| 精品黑人一区二区三区在线观看| 欧美国产日韩一区二区三区| 精品无人区一区二区| 日日橹狠狠爱欧美超碰| 久久久精品免费网站| 在线观看免费观看在线| 久久艹在线视频| 极品束缚调教一区二区网站| 日韩精品视频久久| 国产精品乱人伦| www.97av| 日本精品久久久久影院| 久久综合成人| 又黄又色的网站| 色综合视频在线观看| 欧美人xxx| 国产午夜精品一区| 奇米一区二区三区| 妺妺窝人体色www在线下载| 日韩不卡中文字幕| 黑人一区二区三区| 欧美国产日韩激情| 日本一区二区三区国色天香| 国产偷拍一区二区| 96精品视频在线| 国产高清一区| 亚洲欧美在线不卡| 欧美精品色综合| 色多多在线观看| 干日本少妇视频| 久久婷婷国产综合国色天香| 国产丝袜视频在线观看| 欧美亚洲一区在线|