3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Vue -渐进式JavaScript框架

發布時間:2025/3/21 javascript 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Vue -渐进式JavaScript框架 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

介紹

  • vue 中文網
  • vue github
  • Vue.js 是一套構建用戶界面(UI)的漸進式JavaScript框架

庫和框架的區別

  • 我們所說的前端框架與庫的區別?

Library

庫,本質上是一些函數的集合。每次調用函數,實現一個特定的功能,接著把控制權交給使用者
  • 代表:jQuery
  • jQuery這個庫的核心:DOM操作,即:封裝DOM操作,簡化DOM操作

Framework

框架,是一套完整的解決方案,使用框架的時候,需要把你的代碼放到框架合適的地方,框架會在合適的時機調用你的代碼
  • 框架規定了自己的編程方式,是一套完整的解決方案
  • 使用框架的時候,由框架控制一切,我們只需要按照規則寫代碼

主要區別

  • You call Library, Framework calls you
  • 核心點:誰起到主導作用(控制反轉)

    • 框架中控制整個流程的是框架
    • 使用庫,由開發人員決定如何調用庫中提供的方法(輔助)
  • 好萊塢原則:Don't call us, we'll call you.
  • 框架的侵入性很高(從頭到尾)

MVVM的介紹

  • MVVM,一種更好的UI模式解決方案
  • 從Script到Code Blocks、Code Behind到MVC、MVP、MVVM - 科普

MVC

  • M: Model 數據模型(專門用來操作數據,數據的CRUD)
  • V:View 視圖(對于前端來說,就是頁面)
  • C:Controller 控制器(是視圖和數據模型溝通的橋梁,用于處理業務邏輯)

MVVM組成

  • MVVM ===> M / V / VM
  • M:model數據模型
  • V:view視圖
  • VM:ViewModel 視圖模型

優勢對比

  • MVC模式,將應用程序劃分為三大部分,實現了職責分離
  • 在前端中經常要通過 JS代碼 來進行一些邏輯操作,最終還要把這些邏輯操作的結果現在頁面中。也就是需要頻繁的操作DOM
  • MVVM通過數據雙向綁定讓數據自動地雙向同步

    • V(修改數據) -> M
    • M(修改數據) -> V
    • 數據是核心
  • Vue這種MVVM模式的框架,不推薦開發人員手動操作DOM

Vue中的MVVM

雖然沒有完全遵循 MVVM 模型,Vue 的設計無疑受到了它的啟發。因此在文檔中經常會使用 vm (ViewModel 的簡稱) 這個變量名表示 Vue 實例

學習Vue要轉化思想

  • 不要在想著怎么操作DOM,而是想著如何操作數據!!!

起步 - Hello Vue

  • 安裝:npm i -S vue
<!-- 指定vue管理內容區域,需要通過vue展示的內容都要放到找個元素中 通常我們也把它叫做邊界 數據只在邊界內部解析--> <div id="app">{{ msg }}</div><!-- 引入 vue.js --> <script src="vue.js"></script><!-- 使用 vue --> <script>var vm = new Vue({// el:提供一個在頁面上已存在的 DOM 元素作為 Vue 實例的掛載目標el: '#app',// Vue 實例的數據對象,用于給 View 提供數據data: {msg: 'Hello Vue'}}) </script>

Vue實例

  • 注意 1:先在data中聲明數據,再使用數據
  • 注意 2:可以通過?vm.$data?訪問到data中的所有屬性,或者?vm.msg
var vm = new Vue({data: {msg: '大家好,...'} })vm.$data.msg === vm.msg // true

數據綁定

  • 最常用的方式:Mustache(插值語法),也就是?{{}}?語法
  • 解釋:{{}}從數據對象data中獲取數據
  • 說明:數據對象的屬性值發生了改變,插值處的內容都會更新
  • 說明:{{}}中只能出現JavaScript表達式 而不能解析js語句
  • 注意:Mustache 語法不能作用在 HTML 元素的屬性上
<h1>Hello, {{ msg }}.</h1> <p>{{ 1 + 2 }}</p> <p>{{ isOk ? 'yes': 'no' }}</p><!-- !!!錯誤示范!!! --> <h1 title="{{ err }}"></h1>

雙向數據綁定 Vue two way data binding

  • 雙向數據綁定:將DOM與Vue實例的data數據綁定到一起,彼此之間相互影響

    • 數據的改變會引起DOM的改變
    • DOM的改變也會引起數據的變化
  • 原理:Object.defineProperty中的get和set方法

    • getter和setter:訪問器
    • 作用:指定讀取或設置對象屬性值的時候,執行的操作
  • Vue - 深入響應式原理
  • MDN - Object.defineProperty()
/* defineProperty語法 介紹 */ var obj = {} Object.defineProperty(obj, 'msg', {// 設置 obj.msg = "1" 時set方法會被系統調用 參數分別是設置后和設置前的值set: function (newVal, oldVal) { },// 讀取 obj.msg 時get方法會被系統調用get: function ( newVal, oldVal ) {} })

Vue雙向綁定的極簡實現

  • 剖析Vue原理&實現雙向綁定MVVM
<!-- 示例 --> <input type="text" id="txt" /> <span id="sp"></span><script> var txt = document.getElementById('txt'),sp = document.getElementById('sp'),obj = {}// 給對象obj添加msg屬性,并設置setter訪問器 Object.defineProperty(obj, 'msg', {// 設置 obj.msg 當obj.msg反生改變時set方法將會被調用 set: function (newVal) {// 當obj.msg被賦值時 同時設置給 input/spantxt.value = newValsp.innerText = newVal} })// 監聽文本框的改變 當文本框輸入內容時 改變obj.msg txt.addEventListener('keyup', function (event) {obj.msg = event.target.value }) </script>

動態添加數據的注意點

  • 注意:只有data中的數據才是響應式的,動態添加進來的數據默認為非響應式
  • 可以通過以下方式實現動態添加數據的響應式

    • 1?Vue.set(object, key, value)?- 適用于添加單個屬性
    • 2?Object.assign()?- 適用于添加多個屬性
var vm = new Vue({data: {stu: {name: 'jack',age: 19}} })/* Vue.set */ Vue.set(vm.stu, 'gender', 'male')/* Object.assign 將參數中的所有對象屬性和值 合并到第一個參數 并返回合并后的對象*/ vm.stu = Object.assign({}, vm.stu, { gender: 'female', height: 180 })

異步DOM更新

  • 說明:Vue 異步執行 DOM 更新,監視所有數據改變,一次性更新DOM
  • 優勢:可以去除重復數據,對于避免不必要的計算和 避免重復 DOM 操作上,非常重要
  • 如果需要那到更新后dom中的數據 則需要通過?Vue.nextTick(callback):在DOM更新后,執行某個操作(屬于DOM操作)

    • 實例調用vm.$nextTick(function () {})
methods: {fn() {this.msg = 'change'this.$nextTick(function () {console.log('$nextTick中打印:', this.$el.children[0].innerText);})console.log('直接打印:', this.$el.children[0].innerText);} }

指令

  • 解釋:指令 (Directives) 是帶有?v-?前綴的特殊屬性
  • 作用:當表達式的值改變時,將其產生的連帶影響,響應式地作用于 DOM

v-text

  • 解釋:更新DOM對象的 textContent
<h1 v-text="msg"></h1>

v-html

  • 解釋:更新DOM對象的 innerHTML
<h1 v-html="msg"></h1>

v-bind

  • 作用:當表達式的值改變時,將其產生的連帶影響,響應式地作用于 DOM
  • 語法:v-bind:title="msg"
  • 簡寫::title="msg"
<!-- 完整語法 --> <a v-bind:href="url"></a> <!-- 縮寫 --> <a :href="url"></a>

v-on

  • 作用:綁定事件
  • 語法:v-on:click="say"?or?v-on:click="say('參數', $event)"
  • 簡寫:@click="say"
  • 說明:綁定的事件定義在methods
<!-- 完整語法 --> <a v-on:click="doSomething"></a> <!-- 縮寫 --> <a @click="doSomething"></a>

事件修飾符

  • .stop?阻止冒泡,調用 event.stopPropagation()
  • .prevent?阻止默認行為,調用 event.preventDefault()
  • .capture?添加事件偵聽器時使用事件捕獲模式
  • .self?只當事件在該元素本身(比如不是子元素)觸發時,才會觸發事件
  • .once?事件只觸發一次

v-model

  • 作用:在表單元素上創建雙向數據綁定
  • 說明:監聽用戶的輸入事件以更新數據
  • 案例:計算器
<input type="text" v-model="message" placeholder="edit me"> <p>Message is: {{ message }}</p>

v-for

  • 作用:基于源數據多次渲染元素或模板塊
<!-- 1 基礎用法 --> <div v-for="item in items">{{ item.text }} </div><!-- item 為當前項,index 為索引 --> <p v-for="(item, index) in list">{{item}} -- {{index}}</p> <!-- item 為值,key 為鍵,index 為索引 --> <p v-for="(item, key, index) in obj">{{item}} -- {{key}}</p> <p v-for="item in 10">{{item}}</p>

key屬性

  • 推薦:使用?v-for?的時候提供?key?屬性,以獲得性能提升。
  • 說明:使用 key,VUE會基于 key 的變化重新排列元素順序,并且會移除 key 不存在的元素。
  • vue key
  • vue key屬性的說明
<div v-for="item in items" :key="item.id"><!-- 內容 --> </div>

樣式處理 -class和style

  • 使用方式:v-bind:class="expression"?or?:class="expression"
  • 表達式的類型:字符串、數組、對象(重點)
  • 語法:
<!-- 1 --> <div v-bind:class="{ active: true }"></div> ===> 解析后 <div class="active"></div><!-- 2 --> <div :class="['active', 'text-danger']"></div> ===>解析后 <div class="active text-danger"></div><!-- 3 --> <div v-bind:class="[{ active: true }, errorClass]"></div> ===>解析后 <div class="active text-danger"></div>--- style --- <!-- 1 --> <div v-bind:style="{ color: activeColor, 'font-size': fontSize + 'px' }"></div> <!-- 2 將多個 樣式對象 應用到一個元素上--> <!-- baseStyles 和 overridingStyles 都是data中定義的對象 --> <div v-bind:style="[baseStyles, overridingStyles]"></div>

v-if 和 v-show

  • 條件渲染
  • v-if:根據表達式的值的真假條件,銷毀或重建元素
  • v-show:根據表達式之真假值,切換元素的 display CSS 屬性
<p v-show="isShow">這個元素展示出來了嗎???</p> <p v-if="isShow">這個元素,在HTML結構中嗎???</p>

提升性能:v-pre

  • 說明:vue會跳過這個元素和它的子元素的編譯過程。可以用來顯示原始 Mustache 標簽。跳過大量沒有指令的節點會加快編譯。
<span v-pre>{{ this will not be compiled }}</span>

提升性能:v-once

  • 說明:vue只渲染元素和組件一次。隨后的重新渲染,元素/組件及其所有的子節點將被視為靜態內容并跳過。這可以用于優化更新性能。
<span v-once>This will never change: {{msg}}</span>

過濾器 filter

  • 作用:文本數據格式化
  • 過濾器可以用在兩個地方:{{}}和 v-bind 表達式
  • 兩種過濾器:1 全局過濾器 2 局部過濾器

全局過濾器

  • 說明:通過全局方式創建的過濾器,在任何一個vue實例中都可以使用
  • 注意:使用全局過濾器的時候,需要先創建全局過濾器,再創建Vue實例
  • 顯示的內容由過濾器的返回值決定
Vue.filter('filterName', function (value) {// value 表示要過濾的內容 })
  • 示例:
<div>{{ dateStr | date }}</div> <div>{{ dateStr | date('YYYY-MM-DD hh:mm:ss') }}</div><script>Vue.filter('date', function(value, format) {// value 要過濾的字符串內容,比如:dateStr// format 過濾器的參數,比如:'YYYY-MM-DD hh:mm:ss'}) </script>

局部過濾器

  • 說明:局部過濾器是在某一個vue實例的內容創建的,只在當前實例中起作用
{data: {},// 通過 filters 屬性創建局部過濾器// 注意:此處為 filtersfilters: {filterName: function(value, format) {}} }

按鍵值修飾符

  • 說明:在監聽鍵盤事件時,Vue 允許為?v-on?在監聽鍵盤事件時添加關鍵修飾符
  • 鍵盤事件 - 鍵值修飾符
  • 其他:修飾鍵(.ctrl等)、鼠標按鍵修飾符(.left等)
// 只有在 keyCode 是 13 時調用 vm.submit() @keyup.13="submit" // 使用全局按鍵別名 @keyup.enter="add"---// 通過全局 config.keyCodes 對象自定義鍵值修飾符別名 Vue.config.keyCodes.f2 = 113 // 使用自定義鍵值修飾符 @keyup.enter.f2="add"

監視數據變化 - watch

  • 概述:watch是一個對象,鍵是需要觀察的表達式,值是對應回調函數
  • 作用:當表達式的值發生變化后,會調用對應的回調函數完成響應的監視操作
  • VUE $watch
new Vue({data: { a: 1, b: { age: 10 } },watch: {a: function(val, oldVal) {// val 表示當前值// oldVal 表示舊值console.log('當前值為:' + val, '舊值為:' + oldVal)},// 監聽對象屬性的變化b: {handler: function (val, oldVal) { /* ... */ },// deep : true表示是否監聽對象內部屬性值的變化 deep: true},// 只監視user對象中age屬性的變化'user.age': function (val, oldVal) {},} })

計算屬性

  • 說明:計算屬性是基于它們的依賴進行緩存的,只有在它的依賴發生改變時才會重新求值
  • 注意:Mustache語法({{}})中不要放入太多的邏輯,否則會讓模板過重、難以理解和維護
  • 注意:computed中的屬性不能與data中的屬性同名,否則會報錯
  • Vue computed屬性原理
var vm = new Vue({el: '#app',data: {firstname: 'jack',lastname: 'rose'},computed: {fullname() {return this.firstname + '.' + this.lastname}} })

實例生命周期

  • 所有的 Vue 組件都是 Vue 實例,并且接受相同的選項對象即可 (一些根實例特有的選項除外)。
  • 實例生命周期也叫做:組件生命周期

生命周期介紹

  • vue生命周期鉤子函數
  • 簡單說:一個組件從開始到最后消亡所經歷的各種狀態,就是一個組件的生命周期

生命周期鉤子函數的定義:從組件被創建,到組件掛載到頁面上運行,再到頁面關閉組件被卸載,這三個階段總是伴隨著組件各種各樣的事件,這些事件,統稱為組件的生命周期函數!

  • 注意:Vue在執行過程中會自動調用生命周期鉤子函數,我們只需要提供這些鉤子函數即可
  • 注意:鉤子函數的名稱都是Vue中規定好的!

鉤子函數 - beforeCreate()

  • 說明:在實例初始化之后,數據觀測 (data observer) 和 event/watcher 事件配置之前被調用
  • 注意:此時,無法獲取 data中的數據、methods中的方法

鉤子函數 -?created()

  • 注意:這是一個常用的生命周期,可以調用methods中的方法、改變data中的數據
  • vue實例生命周期 參考1
  • vue實例生命周期 參考2
  • 使用場景:發送請求獲取數據

鉤子函數 - beforeMounted()

  • 說明:在掛載開始之前被調用

鉤子函數 -?mounted()

  • 說明:此時,vue實例已經掛載到頁面中,可以獲取到el中的DOM元素,進行DOM操作

鉤子函數 - beforeUpdated()

  • 說明:數據更新時調用,發生在虛擬 DOM 重新渲染和打補丁之前。你可以在這個鉤子中進一步地更改狀態,這不會觸發附加的重渲染過程。
  • 注意:此處獲取的數據是更新后的數據,但是獲取頁面中的DOM元素是更新之前的

鉤子函數 - updated()

  • 說明:組件 DOM 已經更新,所以你現在可以執行依賴于 DOM 的操作。

鉤子函數 - beforeDestroy()

  • 說明:實例銷毀之前調用。在這一步,實例仍然完全可用。
  • 使用場景:實例銷毀之前,執行清理任務,比如:清除定時器等

鉤子函數 - destroyed()

  • 說明:Vue 實例銷毀后調用。調用后,Vue 實例指示的所有東西都會解綁定,所有的事件監聽器會被移除,所有的子實例也會被銷毀。

axios

  • Promise based HTTP client for the browser and node.js

    • 以Promise為基礎的HTTP客戶端,適用于:瀏覽器和node.js
    • 封裝ajax,用來發送請求,異步獲取數據
  • 安裝:npm i -S axios
  • axios
// 在瀏覽器中使用,直接引入js文件使用下面的GET/POST請求方式即可 // 1 引入 axios.js // 2 直接調用axios提供的API發送請求 created: function () {axios.get(url).then(function(resp) {}) }--- // 配合 webpack 使用方式如下: import Vue from 'vue' import axios from 'axios' // 將 axios 添加到 Vue.prototype 中 Vue.prototype.$axios = axios--- // 在組件中使用: methods: {getData() {this.$axios.get('url').then(res => {}).catch(err => {})} }--- // API使用方式:axios.get(url[, config]) axios.post(url[, data[, config]]) axios(url[, config]) axios(config)

Get 請求

const url = 'http://vue.studyit.io/api/getnewslist'// url中帶有query參數 axios.get('/user?id=89').then(function (response) {console.log(response);}).catch(function (error) {console.log(error);});// url和參數分離,使用對象 axios.get('/user', {params: {id: 12345} })

Post 請求

  • 不同環境中處理 POST請求
  • 默認情況下,axios 會將JS對象序列化為JSON對象。為了使用?application/x-www-form-urlencoded?格式發送請求,我們可以這樣:
// 使用 qs 包,處理將對象序列化為字符串 // npm i -S qs // var qs = require('qs') import qs from 'qs' qs.stringify({ 'bar': 123 }) ===> "bar=123" axios.post('/foo', qs.stringify({ 'bar': 123 }))// 或者: axios.post('/foo', 'bar=123&age=19') const url = 'http://vue.studyit.io/api/postcomment/17' axios.post(url, 'content=點個贊不過份')axios.post('/user', qs.stringify({firstName: 'Fred',lastName: 'Flintstone'})).then(function (response) {console.log(response);}).catch(function (error) {console.log(error);});

全局配置

// 設置請求公共路徑: axios.defaults.baseURL = 'http://vue.studyit.io'

攔截器

  • 攔截器會攔截發送的每一個請求,請求發送之前執行request中的函數,請求發送完成之后執行response中的函數
// 請求攔截器 axios.interceptors.request.use(function (config) {// 所有請求之前都要執行的操作return config;}, function (error) {// 錯誤處理return Promise.reject(error);});// 響應攔截器 axios.interceptors.response.use(function (response) {// 所有請求完成后都要執行的操作return response;}, function (error) {// 錯誤處理return Promise.reject(error);});

自定義指令

  • 作用:進行DOM操作
  • 使用場景:對純 DOM 元素進行底層操作,比如:文本框獲得焦點
  • vue 自定義指令用法實例
  • 兩種指令:1 全局指令 2 局部指令

全局自定義指令

// 第一個參數:指令名稱 // 第二個參數:配置對象,指定指令的鉤子函數 Vue.directive('directiveName', {// bind中只能對元素自身進行DOM操作,而無法對父級元素操作// 只調用一次 指令第一次綁定到元素時調用。在這里可以進行一次性的初始化設置。bind( el,binding, vnode ) {// 參數詳解// el:指令所綁定的元素,可以用來直接操作 DOM 。// binding:一個對象,包含以下屬性:// name:指令名,不包括 v- 前綴。// value:指令的綁定值,等號后面的值 。// oldValue:指令綁定的前一個值,僅在 update 和 componentUpdated 鉤子中可用。無論值是否改變都可用。// expression:字符串形式的指令表達式 等號后面的字符串 形式// arg:傳給指令的參數,可選。例如 v-my-directive:foo 中,參數為 "foo"。// modifiers:指令修飾符。例如:v-directive.foo.bar中,修飾符對象為 { foo: true, bar: true }。// vnode:Vue 編譯生成的虛擬節點。。// oldVnode:上一個虛擬節點,僅在 update 和 componentUpdated 鉤子中可用。},// inserted這個鉤子函數調用的時候,當前元素已經插入頁面中了,也就是說可以獲取到父級節點了inserted ( el,binding, vnode ) {},// DOM重新渲染前update(el,binding, vnode,oldVnode) {},// DOM重新渲染后componentUpdated ( el,binding, vnode,oldVnode ) {},// 只調用一次,指令與元素解綁時調用unbind ( el ) {// 指令所在的元素在頁面中消失,觸發} }) // 簡寫 如果你想在 bind 和 update 時觸發相同行為,而不關心其它的鉤子: Vue.directive('自定義指令名', function( el, binding ) {}) // 例: Vue.directive('color', function(el, binding) {el.style.color = binging.value }) // 使用 注意直接些會被i成data中的數據“red” 需要字符串則嵌套引號"'red'" <p v-color="'red'"></p>

局部自定義指令

var vm = new Vue({el : "#app",directives: {directiveName: { }} })
  • vue 剖析Vue原理&實現雙向綁定MVVM

組件

組件系統是 Vue 的另一個重要概念,因為它是一種抽象,允許我們使用小型、獨立和通常可復用的組件構建大型應用。仔細想想,幾乎任意類型的應用界面都可以抽象為一個組件樹
  • 創建組件的兩種方式:1 全局組件 2 局部組件

全局組件

  • 說明:全局組件在所有的vue實例中都可以使用
  • 注意:先注冊組件,再初始化根實例
// 1 注冊全局組件 Vue.component('my-component', {// template 只能有一個根元素template: '<p>A custom component!</p>',// 組件中的 `data` 必須是函數 并且函數的返回值必須是對象data() {return {msg: '注意:組件的data必須是一個函數!!!'}} })// 2 使用:以自定義元素的方式 <div id="example"><my-component></my-component> </div>// =====> 渲染結果 <div id="example"><p>A custom component!</p> </div>// 3 template屬性的值可以是:- 1 模板字符串- 2 模板id template: '#tpl' <script type="text/x-template" id="tpl"><p>A custom component!</p> </script>
  • extend:使用基礎 Vue 構造器,創建一個“子類”。參數是一個包含組件選項的對象。
// 注冊組件,傳入一個擴展過的構造器 Vue.component('my-component', Vue.extend({ /* ... */ }))// 注冊組件,傳入一個選項對象 (自動調用 Vue.extend) Vue.component('my-component', { /* ... */ })var Home = Vue.extend({template: '',data() {} }) Vue.component('home', Home)

局部組件

  • 說明:局部組件,是在某一個具體的vue實例中定義的,只能在這個vue實例中使用
var Child = {template: '<div>A custom component!</div>' }new Vue({// 注意:此處為 componentscomponents: {// <my-component> 將只在當前vue實例中使用// my-component 為組件名 值為配置對象 'my-component': {template: ``,data () { return { } },props : []}} })

is特性

在某些特定的標簽中只能存在指定表恰 如ul > li 如果要瀏覽器正常解析則需要使用is <!-- 案例 --> <ul id="app"><!-- 不能識別 --><my-li></my-li> 正常識別<li is="my-li"></li> </ul><script>var vm = new Vue({el: "#app",components : {myLi : {template : `<li>內容</li>`}}}) </script>

組件通訊

父組件到子組件

  • 方式:通過子組件props屬性來傳遞數據 props是一個數組
  • 注意:屬性的值必須在組件中通過props屬性顯示指定,否則,不會生效
  • 說明:傳遞過來的props屬性的用法與data屬性的用法相同
<div id="app"><!-- 如果需要往子組件總傳遞父組件data中的數據 需要加v-bind="數據名稱" --><hello v-bind:msg="info"></hello><!-- 如果傳遞的是字面量 那么直接寫--><hello my-msg="abc"></hello> </div><!-- js --> <script>new Vue({el: "#app",data : {info : 15},components: {hello: {// 創建props及其傳遞過來的屬性props: ['msg', 'myMsg'],template: '<h1>這是 hello 組件,這是消息:{{msg}} --- {{myMsg}}</h1>'}}}) </script>

子組件到父組件

方式:父組件給子組件傳遞一個函數,由子組件調用這個函數

  • 說明:借助vue中的自定義事件(v-on:cunstomFn="fn")

步驟:

  • 1、在父組件中定義方法 parentFn
  • 2、在子組件 組件引入標簽 中綁定自定義事件 v-on:自定義事件名="父組件中的方法" ==> @pfn="parentFn"
  • 3、子組件中通過$emit()觸發自定義事件事件 this.$emit(pfn,參數列表。。。)
<hello @pfn="parentFn"></hello><script>Vue.component('hello', {template: '<button @click="fn">按鈕</button>',methods: {// 子組件:通過$emit調用fn() {this.$emit('pfn', '這是子組件傳遞給父組件的數據')}}})new Vue({methods: {// 父組件:提供方法parentFn(data) {console.log('父組件:', data)}}}) </script>

非父子組件通訊

在簡單的場景下,可以使用一個空的 Vue 實例作為事件總線
  • $on():綁定自定義事件
var bus = new Vue()// 在組件 B 綁定自定義事件 bus.$on('id-selected', function (id) {// ... }) // 觸發組件 A 中的事件 bus.$emit('id-selected', 1)
  • 示例:組件A ---> 組件B
<!-- 組件A: --> <com-a></com-a> <!-- 組件B: --> <com-b></com-b><script>// 中間組件var bus = new Vue()// 通信組件var vm = new Vue({el: '#app',components: {comB: {template: '<p>組件A告訴我:{{msg}}</p>',data() {return {msg: ''}},created() {// 給中間組件綁定自定義事件 注意:如果用到this 需要用箭頭函數bus.$on('tellComB', (msg) => {this.msg = msg})}},comA: {template: '<button @click="emitFn">告訴B</button>',methods: {emitFn() {// 觸發中間組件中的自定義事件bus.$emit('tellComB', '土豆土豆我是南瓜')}}}}}) </script>

內容分發

  • 通過<slot></slot> 標簽指定內容展示區域

案例:

<!-- html代碼 --> <div id="app"><hello><!-- 如果只有一個slot插槽 那么不需要指定名稱 --><p slot="插槽名稱">我是額外的內容</p></hello> </div> // js代碼 new vue({el : "#app",components : {hello : {template : `<div><p>我是子組件中的內容</p><slot name="名稱"></slot></div>`}} })

獲取組件(或元素) - refs

  • 說明:vm.$refs?一個對象,持有已注冊過 ref 的所有子組件(或HTML元素)
  • 使用:在 HTML元素 中,添加ref屬性,然后在JS中通過vm.$refs.屬性來獲取
  • 注意:如果獲取的是一個子組件,那么通過ref就能獲取到子組件中的data和methods
<div id="app"><div ref="dv"></div><my res="my"></my> </div><!-- js --> <script>new Vue({el : "#app",mounted() {this.$refs.dv //獲取到元素this.$refs.my //獲取到組件},components : {my : {template: `<a>sss</a>`}}}) </script>

SPA -單頁應用程序

SPA: Single Page Application

單頁Web應用(single page application,SPA),就是只有一個Web頁面的應用, 是加載單個HTML頁面,并在用戶與應用程序交互時動態更新該頁面的Web應用程序。
  • 單頁面應用程序:

    • 只有第一次會加載頁面, 以后的每次請求, 僅僅是獲取必要的數據.然后, 由頁面中js解析獲取的數據, 展示在頁面中
  • 傳統多頁面應用程序:

    • 對于傳統的多頁面應用程序來說, 每次請求服務器返回的都是一個完整的頁面

優勢

  • 1 減少了請求體積,加快頁面響應速度,降低了對服務器的壓力
  • 2 更好的用戶體驗,讓用戶在web app感受native app的流暢

實現思路和技術點

  • 1 ajax
  • 2 錨點的使用(window.location.hash #)
  • 3 hashchange 事件 window.addEventListener("hashchange",function () {})
  • 4 監聽錨點值變化的事件,根據不同的錨點值,請求相應的數據
  • 5 原本用作頁面內部進行跳轉,定位并展示相應的內容

路由

  • 路由即:瀏覽器中的哈希值(# hash)與展示視圖內容(template)之間的對應規則
  • vue中的路由是:hash 和 component的對應關系

    在 Web app 中,通過一個頁面來展示和管理整個應用的功能。
    SPA往往是功能復雜的應用,為了有效管理所有視圖內容,前端路由 應運而生!
    簡單來說,路由就是一套映射規則(一對一的對應規則),由開發人員制定規則。
    當URL中的哈希值(# hash)發生改變后,路由會根據制定好的規則,展示對應的視圖內容

基本使用

  • 安裝:npm i -S vue-router
<div id="app"><!-- 5 路由入口 指定跳轉到只定入口 --><router-link to="/home">首頁</router-link><router-link to="/login">登錄</router-link><!-- 7 路由出口:用來展示匹配路由視圖內容 --><router-view></router-view></div><!-- 1 導入 vue.js --><script src="./vue.js"></script><!-- 2 導入 路由文件 --><script src="./node_modules/vue-router/dist/vue-router.js"></script><script>// 3 創建兩個組件const Home = Vue.component('home', {template: '<h1>這是 Home 組件</h1>'})const Login = Vue.component('login', {template: '<h1>這是 Login 組件</h1>'})// 4 創建路由對象const router = new VueRouter({routes: [// 路徑和組件一一對應{ path: '/home', component: Home },{ path: '/login', component: Login }]})var vm = new Vue({el: '#app',// 6 將路由實例掛載到vue實例router})</script>

重定向

// 將path 重定向到 redirect { path: '/', redirect: '/home' }

路由其他配置

  • 路由導航高亮

    • 說明:當前匹配的導航鏈接,會自動添加router-link-exact-active router-link-active類
    • 配置:linkActiveClass
  • 匹配路由模式

    • 配置:mode
new Router({routers:[],mode: "hash", //默認hash | history 可以達到隱藏地址欄hash值 | abstract,如果發現沒有瀏覽器的 API 則強制進入linkActiveClass : "now" //當前匹配的導航鏈接將被自動添加now類 })

路由參數

  • 說明:我們經常需要把某種模式匹配到的所有路由,全都映射到同一個組件,此時,可以通過路由參數來處理
  • 語法:/user/:id
  • 使用:當匹配到一個路由時,參數值會被設置到 this.$route.params
  • 其他:可以通過 $route.query 獲取到 URL 中的查詢參數 等
// 方式一<router-link to="/user/1001">如果你需要在模版中使用路由參數 可以這樣 {{$router.params.id}}</router-link>// 方式二<router-link :to="{path:'/user',query:{name:'jack',age:18}}">用戶 Rose</router-link><script>// 路由var router = new Router({routers : [// 方式一 注意 只有/user/1001這種形式能被匹配 /user | /user/ | /user/1001/ 都不能被匹配// 將來通過$router.params獲取參數返回 {id:1001}{ path: '/user/:id', component: User }, // 方式二{ path: "user" , component: User}]})// User組件:const User = {template: `<div>User {{ $route.params.id }}</div>`}</script> <!-- 如果要子啊vue實例中獲取路由參數 則使用this.$router.params 獲取路由參數對象 --><!-- {{$router.query}} 獲取路由中的查詢字符串 返回對象 -->

嵌套路由 - 子路由

  • 路由是可以嵌套的,即:路由中又包含子路由
  • 規則:父組件中包含 router-view,在路由規則中使用 children 配置
// 父組件:const User = Vue.component('user', {template: `<div class="user"><h2>User Center</h2><router-link to="/user/profile">個人資料</router-link><router-link to="/user/posts">崗位</router-link><!-- 子路由展示在此處 --><router-view></router-view></div>`})// 子組件[簡寫]const UserProfile = {template: '<h3>個人資料:張三</h3>'}const UserPosts = {template: '<h3>崗位:FE</h3>'}// 路由var router =new Router({routers : [{ path: '/user', component: User,// 子路由配置:children: [{// 當 /user/profile 匹配成功,// UserProfile 會被渲染在 User 的 <router-view> 中path: 'profile',component: UserProfile},{// 當 /user/posts 匹配成功// UserPosts 會被渲染在 User 的 <router-view> 中path: 'posts',component: UserPosts}]}]})

前端模塊化

為什么需要模塊化
  • 1 最開始的js就是為了實現客戶端驗證以及一些簡單的效果
  • 2 后來,js得到重視,應用越來越廣泛,前端開發的復雜度越來越高
  • 3 舊版本的js中沒有提供與模塊(module)相關的內容

模塊的概念

  • 在js中,一個模塊就是實現特定功能的文件(js文件)
  • 遵循模塊的機制,想要什么功能就加載什么模塊
  • 模塊化開發需要遵循規范

模塊化解決的問題

  • 1 命名沖突
  • 2 文件依賴(加載文件)
  • 3 模塊的復用
  • 4 統一規范和開發方式

JS實現模塊化的規范

  • AMD 瀏覽器端

    • requirejs
  • CommonJS nodejs

    • 加載模塊:require()
    • 導出模塊:module.exports = {} / exports = {}
  • ES6 中的 import / export
  • CMD 瀏覽器端

    • 玉伯(阿里前端大神) -> seajs
  • UMD 通用模塊化規范,可以兼容 AMD、CommonJS、瀏覽器中沒有模塊化規范 等這些語法

AMD 的使用

Asynchronous Module Definition:異步模塊定義,瀏覽器端模塊開發的規范 代表:require.js 特點:模塊被異步加載,模塊加載不影響后面語句的運行

1、定義模塊

// 語法:define(name, dependencies?, factory);// name表示:當前模塊的名稱,是一個字符串 可有可無// dependencies表示:當前模塊的依賴項,是一個數組無論依賴一項還是多項 無則不寫// factory表示:當前模塊要完成的一些功能,是一個函數// 定義對象模塊define({})// 定義方法模塊define(function() {return {}})// 定義帶有依賴項的模塊define(['js/a'], function() {})

2、加載模塊

// - 注意:require的第一個參數必須是數組// 參數必須是數組 表示模塊路徑 以當前文件為基準,通過回調函數中的參數獲取加載模塊中的變量 參數與模塊按照順序一一對應require(['a', 'js/b'], function(a, b) {// 使用模塊a 和 模塊b 中的代碼})

3、路徑查找配置

  • requirejs 默認使用 baseUrl+paths 的路徑解析方式
  • 可以使用以下方式避開此設置:

    • 1 以.js結尾
    • 2 以 / 開始
    • 3 包含協議:https://?或?http://
// 配置示例// 注意配置應當在使用之前require.config({baseUrl: './js' // 配置基礎路徑為:當前目錄下的js目錄})require(['a']) // 查找 基礎路徑下的 ./js/a.js// 簡化加載模塊路徑require.config({baseUrl: './js',// 配置一次即可,直接通過路徑名稱(template || jquery)加載模塊paths: {template: 'assets/artTemplate/template-native',jquery: 'assets/jquery/jquery.min'}})// 加載jquery template模塊require(['jquery', 'template'])

4、非模塊化和依賴項支持

  • 1 添加模塊的依賴模塊,保證加載順序(deps)
  • 2 將非模塊化模塊,轉化為模塊化(exports)
// 示例require.config({baseUrl: './js',paths: {// 配置路徑noModule: 'assets/demo/noModule'},// 配置不符合規范的模塊項shim: {// 模塊名稱noModule: {deps: [], // 依賴項exports: 'sayHi' // 導出模塊中存在的函數或變量}}});// 注意點 如果定義模塊的時候,指定了模塊名稱,需要使用該名稱來引用模塊// 定義 這個模塊名稱與paths中的名稱相同define('moduleA', function() {})// 導入require.config({paths: {// 此處的模塊名:moduleAmoduleA: 'assets/demo/moduleA'}})

5、路徑加載規則

  • 路徑配置的優先級:

    • 1 通過 config 配置規則查找
    • 2 通過 data-main 指定的路徑查找
    • 3 以引入 requirejs 的頁面所在路徑為準查找
<!-- 設置data-main屬性1 data-main屬性指定的文件也會同時被加載2 用于指定查找其他模塊的基礎路徑--><script src="js/require.js" data-main="js/main"></script>

Webpack

  • webpack 官網
  • bundle?[?b?ndl]?捆綁,收集,歸攏,把…塞入
1 webpack 將帶有依賴項的各個模塊打包處理后,變成了獨立的瀏覽器能夠識別的文件 2 webpack 合并以及解析帶有依賴項的模塊

概述

webpack 是一個現代 JavaScript 應用程序的模塊打包器(特點 module、 bundler)?
webpack 是一個模塊化方案(預編譯)?
webpack獲取具有依賴關系的模塊,并生成表示這些模塊的靜態資源
  • 四個核心概念:入口(entry)、輸出(output)、加載器loader、插件(plugins)
對比 模塊化方案: webpack 和 requirejs(通過編寫代碼的方式將前端的功能,劃分成獨立的模塊)browserify 是與 webpack 相似的模塊化打包工具webpack 預編譯 (在開發階段通過webpack進行模塊化處理, 最終項目上線, 就不在依賴于 webpack) requirejs 線上的編譯( 代碼運行是需要依賴與 requirejs 的 )

webpack起源

  • webpack解決了現存模塊打包器的兩個痛點:

    • 1?Code Spliting?- 代碼分離 按需加載
    • 2?靜態資源的模塊化處理方案

webpack與模塊

  • 前端模塊系統的演進
  • 在webpack看來:所有的靜態資源都是模塊
  • webpack 模塊能夠識別以下等形式的模塊之間的依賴:
  • JS的模塊化規范:

    • ES2015?import?export
    • CommonJS?require()?module.exports
    • AMD?define?和?require
  • 非JS等靜態資源:

    • css/sass/less 文件中的?@import
    • 圖片連接,比如:樣式?url(...)?或 HTML?<img src=...>
    • 字體 等

webpack文檔和資源

  • webpack 中文網
  • webpack 1.0
  • webpack 2.x+
  • 入門Webpack,看這篇就夠了

安裝webpack

  • 全局安裝:npm i -g webpack

    • 目的:在任何目錄中通過CLI使用?webpack?這個命令
  • 項目安裝:npm i -D webpack

    • 目的:執行當前項目的構建

webpack的基本使用

  • 安裝:npm i -D webpack
  • webpack的兩種使用方式:1 命令行 2 配置文件(webpack.config.js)

命令行方式演示 - 案例:隔行變色

  • 1 使用npm init -y?初始package.json,使用npm來管理項目中的包
  • 2 新建index.html和index.js,實現隔行變色功能
  • 3 運行webpack src/js/index.js dist/bundle.js進行打包構建,語法是:webpack 入口文件 輸出文件
  • 4 注意:需要在頁面中引入 輸出文件 的路徑(此步驟可通過配置webpack去掉)
/*src/js/index.js */// 1 導入 jQuery import $ from 'jquery' // 2 獲取頁面中的li元素 const $lis = $('#ulList').find('li') // 3 隔行變色 // jQuery中的 filter() 方法用來過濾jquery對象 $lis.filter(':odd').css('background-color', '#def') $lis.filter(':even').css('background-color', 'skyblue')//命令行運行 `webpack src/js/index.js dist/bundle.js 目錄生成在命令行運行目錄 /*運行流程:1、webpack 根據入口找到入口文件2、分析js中的模塊化語法 3、將所有關聯文件 打包合并輸出到出口 */

webpack-dev-server 配置

一、package.json配置方式

  • 安裝:npm i -D webpack-dev-server
  • 作用:配合webpack,創建開發環境(啟動服務器、監視文件變化、自動編譯、刷新瀏覽器等),提高開發效率
  • 注意:無法直接在終端中執行?webpack-dev-server,需要通過?package.json?的?scripts實現
  • 使用方式:npm run dev
// 參數解釋 注意參數是無序的 有值的參數空格隔開 // --open 自動打開瀏覽器 // --contentBase ./ 指定瀏覽器 默認打開的頁面路徑中的 index.html 文件 // --open 自動打開瀏覽器 // --port 8080 端口號 // --hot 熱更新,只加載修改的文件(按需加載修改的內容),而非全部加載 "scripts": {"dev": "webpack-dev-server --open --contentBase ./ --port 8080 --hot" }

二、webpack.config.js 配置方式(推薦)

var path = require('path') module.exports = {// 入口文件entry: path.join(__dirname, 'src/js/index.js'),// 輸出文件output: {path: path.join(__dirname, 'dist'), // 輸出文件的路徑filename: 'bundle.js' // 輸出文件的名稱} }const webpack = require('webpack')devServer: {// 服務器的根目錄 Tell the server where to serve content from// https://webpack.js.org/configuration/dev-server/#devserver-contentbasecontentBase: path.join(__dirname, './'),// 自動打開瀏覽器open: true,// 端口號port: 8888,// --------------- 1 熱更新 -----------------hot: true },plugins: [// ---------------- 2 啟用熱更新插件 ----------------new webpack.HotModuleReplacementPlugin() ]
  • html-webpack-plugin 插件

    • 安裝:npm i -D html-webpack-plugin
    • 作用:根據模板,自動生成html頁面
    • 優勢:頁面存儲在內存中,自動引入bundle.js、css等文件
/* webpack.config.js */ const htmlWebpackPlugin = require('html-webpack-plugin') plugins: [new htmlWebpackPlugin({// 模板頁面路徑template: path.join(__dirname, './index.html'),// 在內存中生成頁面路徑,默認值為:index.htmlfilename: 'index.html'}) ]

Loaders(加載器)

  • webpack - Loaders
  • webpack - 管理資源示例
webpack enables use of loaders to preprocess files. This allows you to bundle any static resource way beyond JavaScript.
  • webpack只能處理JavaScript資源
  • webpack通過loaders處理非JavaScript靜態資源

1、 CSS打包

  • 安裝:npm i -D style-loader css-loader
  • 注意:use中模塊的順序不能顛倒,加載順序:從右向左加載
/* 在index.js 導入 css 文件*/ import './css/app.css'/* webpack.config.js 配置各種資源文件的loader加載器*/ module: {// 配置匹配規則rules: [// test 用來配置匹配文件規則(正則)// use 是一個數組,按照從后往前的順序執行加載{test: /\.css$/, use: ['style-loader', 'css-loader']},] }

2、 使用webpack打包sass文件

  • 安裝:npm i -D sass-loader node-sass
  • 注意:sass-loader?依賴于?node-sass?模塊
/* webpack.config.js */ // 參考:https://webpack.js.org/loaders/sass-loader/#examples // "style-loader" :creates style nodes from JS strings 創建style標簽 // "css-loader" :translates CSS into CommonJS 將css轉化為CommonJS代碼 // "sass-loader" :compiles Sass to CSS 將Sass編譯為css module:{rules:[{test: /\.(scss|sass)$/, use: ['style-loader', 'css-loader', 'sass-loader']},] }

3、 圖片和字體打包

  • 安裝:npm i -D url-loader file-loader
  • file-loader:加載并重命名文件(圖片、字體 等)
  • url-loader:將圖片或字體轉化為base64編碼格式的字符串,嵌入到樣式文件中
/* webpack.config.js */ module: {rules:[// 打包 圖片文件{ test: /\.(jpg|png|gif|jpeg)$/, use: 'url-loader' },// 打包 字體文件{ test: /\.(woff|woff2|eot|ttf|otf)$/, use: 'file-loader' }] }

圖片打包細節

  • limit參數的作用:(單位為:字節(byte))

    • 當圖片文件大小(字節)小于指定的limit時,圖片被轉化為base64編碼格式
    • 當圖片文件大小(字節)大于等于指定的limit時,圖片被重命名以url路徑形式加載(此時,需要file-loader來加載圖片)
  • 圖片文件重命名,保證相同文件不會被加載多次。例如:一張圖片(a.jpg)拷貝一個副本(b.jpg),同時引入這兩張圖片,重命名后只會加載一次,因為這兩張圖片就是同一張
  • 文件重命名以后,會通過MD5加密的方式,來計算這個文件的名稱
/* webpack.config.js */module: {rules: [// {test: /\.(jpg|png|gif|jpeg)$/, use: 'url-loader?limit=100'},{test: /\.(jpg|png|gif|jpeg)$/,use: [{loader: 'url-loader',options: {limit: 8192}}]}] }

字體文件打包說明

  • 處理方式與圖片相同,可以使用:file-loader或url-loader

babel

  • babel
  • es2015-loose
  • babel全家桶
  • 安裝:npm i -D babel-core babel-loader
  • 安裝:npm i -D babel-preset-env

基本使用(兩步)

  • 第一步:
/* webpack.config.js */module: {rules: [// exclude 排除,不需要編譯的目錄,提高編譯速度{test: /\.js$/, use: 'babel-loader', exclude: /node_modules/}] }
  • 第二步:在項目根目錄中新建.babelrc配置文件
/* 創建 .babelrc 文件*/ // 將來babel-loader運行的時候,會檢查這個配置文件,并讀取相關的語法和插件配置 {"presets": ["env"] }

babel的說明

  • babel的作用:

    • 1 語法轉換:將新的ES語法轉化為瀏覽器能識別的語法(babel-preset-*)
    • 2 polyfill瀏覽器兼容:讓低版本瀏覽器兼容最新版ES的API

babel-preset-*

Babel通過語法轉換器,能夠支持最新版本的JavaScript語法?
babel-preset-* 用來指定我們書寫的是什么版本的JS代碼
  • 作用:將新的ES語法轉化為瀏覽器能識別的ES5代碼
  • ES6語法提案的批準流程

    • ES2015 也就是 ES6, 下一個版本是ES7, 從 ES6 到 ES7之間經歷了 5 個階段
    • babel-preset-es2015 轉換es6的語法
    • babel-preset-stage-0 轉換比es6更新的語法
Stage 0 - Strawman(展示階段) Stage 1 - Proposal(征求意見階段) Stage 2 - Draft(草案階段) Stage 3 - Candidate(候選人階段) Stage 4 - Finished(定案階段)Stage 0 is "i've got a crazy idea", stage 1 is "this idea might not be stupid", stage 2 is "let's use polyfills and transpilers to play with it", stage 3 is "let's let browsers implement it and see how it goes", stage 4 is "now it's javascript".

babel-polyfill 和 transform-runtime

  • 作用:實現瀏覽器對不支持API的兼容(兼容舊環境、填補)

    • 在低版本瀏覽器中使用高級的ES6或ES7的方法或函數,比如:'abc'.padStart(10)
  • 方式一 polyfill
  • 方式二 transform-runtime
  • 方式一:npm i -S babel-polyfill
  • 方式二:npm i -D babel-plugin-transform-runtime?和?npm i -S babel-runtime

    • 注意:babel-runtime包中的代碼會被打包到你的代碼中(-S)
區別: polyfill 所有兼容性問題,都可以通過polyfill解決(包括:實例方法)、污染全局環境 runtime 除了實例方法以外,其他兼容新問題都能解決、不污染全局環境polyfill:如果想要支持全局對象(比如:`Promise`)、靜態方法(比如:`Object.assign`)或者**實例方法**(比如:`String.prototype.padStart`)等,那么就需要使用`babel-polyfill`babel-runtime :提供了兼容舊環境的函數,使用的時候,需要我們自己手動引入比如: const Promise = require('babel-runtime/core-js/promise')存在的問題:1 手動引入太繁瑣2 多個文件引入同一個helper(定義),造成代碼重復,增加代碼體積 babel-plugin-transform-runtime:1 自動引入helper(比如,上面引入的 Promise)2 babel-runtime提供helper定義,引入這個helper即可使用,避免重復3 依賴于 babel-runtime 插件transform-runtime插件的使用:直接在 .bablerc 文件中,添加一個 plugins 的配置項即可!!!"plugins": ["transform-runtime"] /*babel-polyfill 的使用步驟:1 main.js */ // 第一行引入 require("babel-polyfill")var s = 'abc'.padStart(4) console.log(s)// 2 webpack.config.js 配置 module.exports = {entry: ['babel-polyfill', './js/main.js'] }

總結

babel-core babel核心包babel-loader 用來解析js文件babel-preset-* 新ES語法的解析和轉換transform-runtime / babel-polyfill 兼容舊瀏覽器,到達支持新API目的// 判斷瀏覽器是否兼容 padStart 這個 API if (!String.prototype.padStart) {// 如果不兼容, 就自己模擬 padStart的功能實現一份String.prototype.padStart = function padStart(targetLength,padString) {} }

vue單文件組件

  • vue-loader
  • single-file components(單文件組件)
  • 后綴名:.vue,該文件需要被預編譯后才能在瀏覽器中使用
  • 注意:單文件組件依賴于兩個包?vue-loader?/?vue-template-compiler
  • 安裝:npm i -D vue-loader vue-template-compiler
<!-- App.vue 示例代碼: --> <template><div><h1>VUE 單文件組件示例 -- App.vue</h1><p>這是 模板內容</p></div> </template><script>// 組件中的邏輯代碼export default {} </script><style> /* 組件樣式 */ h1 {color: red; } </style> // webpack.config.js 配置: module: {rules: [{test: /\.vue$/,loader: 'vue-loader'}] }

使用單文件組件

/* main.js */import Vue from 'vue' // 導入 App 組件 import App from './App.vue'const vm = new Vue({el: '#app',// 通過 render 方法,渲染App組件render: c => c(App) })

單文件組件使用步驟

  • 1 安裝:npm i -D vue-loader vue-template-compiler
  • 2 在?webpack.config.js?中配置?.vue?文件的loader

    • { test: /\.vue$/, use: 'vue-loader' }
  • 3 創建?App.vue?單文件組件,注意:App可以是任意名稱
  • 4 在?main.js?入口文件中,導入?vue?和?App.vue組件,通過 render 將組件與實例掛到一起

單文件組件+路由

  • vue - Vue.use
  • Vue.use 和 路由
import Vue from 'vue' import App from './App.vue'// ------------- vue路由配置 開始 -------------- import Home from './components/home/Home.vue' import Login from './components/login/Login.vue'// 1 導入 路由模塊 import VueRouter from 'vue-router' // 2 ** 調用use方法使用插件 ** Vue.use(VueRouter) // 3 創建路由對象 const router = new VueRouter({routes: [{ path: '/home', component: Home },{ path: '/login', component: Login }] })// ------------- vue路由配置 結束 --------------const vm = new Vue({el: '#app',render: c => c(App),// 4 掛載到 vue 實例中router })

Mint-UI

  • 基于 Vue.js 的移動端組件庫
  • Mint-UI

快速開始

  • 安裝:npm i -S mint-ui
// 1 導入 mint-ui模塊 import MintUI from 'mint-ui' // 2 導入 樣式 import 'mint-ui/lib/style.css' // 3 注冊插件 Vue.use(MintUI)

MUI

  • MUI
  • MUI 也是移動端的UI庫
  • 使用:從github下載包,找到dist文件夾,只需要導入樣式即可
// 只需要導入 MUI的樣式 即可,根據MUI的例子,直接使用HTML結果即可 // 導入樣式 import './lib/mui/css/mui.min.css'

ElementUI

  • 這是PC端的UI組件庫
  • 安裝:npm i -S element-ui
  • 餓了嗎 - ElementUI
{"presets": [["es2015", { "modules": false }], "stage-0"],"plugins": [["component", [{"libraryName": "mint-ui","style": true},{"libraryName": "element-ui","styleLibraryName": "theme-default"}]]] }

Webpack 發布項目

  • webpack 打包的各種坑
  • webpack?命令能夠生成dist目錄到磁盤中,最終,把打包后的代碼,部署服務器中去
  • webpack-dev-server?僅是在內存中生成的文件,并沒有寫到磁盤中,所以,只能在開發期間使用

創建項目發布配置文件

  • 開發期間配置文件:webpack.config.js
  • 項目發布配置文件:webpack.prod.js?(文件名稱非固定 production 生產環境)
  • 命令:webpack --config webpack.prod.js?指定配置文件名稱運行webpack
  • 參數:--display-error-details?用于顯示webpack打包的錯誤信息
/* package.json */"scripts": {"build": "webpack --config webpack.prod.js" } 1 在項目根目錄中創建 webpack.prod.js 文件 2 在 package.json 中, 配置一個 scripts 3 在 終端中 通過 npm run build 對項目進行打包

打包處理過程

1 刪除掉 devServer 相關的配置項 2 將圖片和字體文件輸出到指定的文件夾中 3 自動刪除dist目錄 4 分離第三方包(將使用的vue等第三方包抽離到 vender.js 中) 5 壓縮混淆JS 以及 指定生成環境 6 抽取和壓縮CSS文件 7 壓縮HTML頁面 8 配合vue的異步組件,實現按需加載功能

處理圖片路徑

  • 注意:如果limit小于比圖片大,那么圖片將被轉化為base64編碼格式
  • name參數介紹
/* webpack.prod.js */ // 處理URL路徑的loader{test: /\.(jpg|png|gif|bmp|jpeg)$/,use: {loader: 'url-loader',options: {limit: 8192,name: 'images/[hash:7].[ext]' // 作用:將圖片輸出到images文件夾中,文件名采用7位的哈希值(MD5),并且保持原來的圖片文件擴展名// name:指定文件輸出路徑和輸出文件命令規則// [hash:7]:表示使用7位哈希值代表文件名稱// [ext]:表示保持文件原有后綴名// name: 'imgs/img-[hash:7].[ext]'}} },

自動刪除dist目錄

  • 安裝:npm i -D clean-webpack-plugin
  • 作用: 每次打包之前, 刪除上一次打包的dist目錄
/* webpack.prod.js */ const cleanWebpackPlugin = require('clean-webpack-plugin')plugins: [// 創建一個刪除文件夾的插件,刪除dist目錄new cleanWebpackPlugin(['./dist']) ]

分離第三方包

  • 目的:將公共的第三方包,抽離為一個單獨的包文件,這樣防止重復打包!

    • 例如:main.js、router、vuex中都引入了vue,不分離的話,vue會被打包3次
    • 抽離后, vue文件只會被打包一次, 用到的地方僅僅是引用
/* webpack.prod.js */// 1 入口 -- 打包文件的入口 entry: {// 項目代碼入口app: path.join(__dirname, './src/js/main.js'),// 第三方包入口vendor: ['vue', 'vue-router', 'axios'] },output: {// 2 修改輸出文件路徑和命名規則filename: 'js/[name].[chunkhash].js', },plugins: [// 3 抽離第三方包new webpack.optimize.CommonsChunkPlugin({// 將 entry 中指定的 ['vue', 'vue-router', 'axios'] 打包到名為 vendor 的js文件中// 第三方包入口名稱,對應 entry 中的 vendor 屬性name: 'vendor',}), ]

壓縮混淆JS

  • 注意:uglifyjs 無法壓縮ES6的代碼
plugins: [// 優化代碼// https://github.com/webpack-contrib/uglifyjs-webpack-plugin/tree/v0.4.6new webpack.optimize.UglifyJsPlugin({// 壓縮compress: {// 移除警告warnings: false}}),// 指定環境為生產環境:vue會根據這一項啟用壓縮后的vue文件new webpack.DefinePlugin({'process.env': {'NODE_ENV': JSON.stringify('production')}}) ]

抽取和壓縮CSS文件

  • 安裝:抽離?npm i -D extract-text-webpack-plugin
  • 安裝:壓縮?npm i -D optimize-css-assets-webpack-plugin
  • webpack 抽離CSS文檔
  • 壓縮抽離后的CSS
壓縮和抽離CSS報錯的說明: Error processing file: css/style.css postcss-svgo: Error in parsing SVG: Unquoted attribute value原因:壓縮和抽離CSS的插件中只允許 SVG 使用雙引號 /* webpack.prod.js */// 分離 css 到獨立的文件中 const ExtractTextPlugin = require("extract-text-webpack-plugin"); // 壓縮 css 資源文件 const OptimizeCssAssetsPlugin = require('optimize-css-assets-webpack-plugin')// bug描述: 生成后面的css文件中圖片路徑錯誤,打開頁面找不到圖片 // 解決:google搜索 webpack css loader 樣式圖片路徑 output: {// ...// https://doc.webpack-china.org/configuration/output/#output-publicpath// 設置公共路徑publicPath: '/', },module: {rules: [{test: /\.css$/,use: ExtractTextPlugin.extract({fallback: "style-loader",use: "css-loader"})},{test: /\.scss$/,use: ExtractTextPlugin.extract({fallback: "style-loader",use: ['css-loader', 'sass-loader']})},] }, plugins: [// 通過插件抽離 css (參數)new ExtractTextPlugin("css/style.css"),// 抽離css 的輔助壓縮插件new OptimizeCssAssetsPlugin() ]

壓縮HTML頁面

  • 詳細的配置可以參考html-minifier
new htmlWebpackPlugin({// 模板頁面template: path.join(__dirname, './index.html'),// 壓縮HTMLminify: {// 移除空白collapseWhitespace: true,// 移除注釋removeComments: true,// 移除屬性中的雙引號removeAttributeQuotes: true} }),

vue配合webpack實現路由按需加載

  • Vue 路由懶加載
  • Vue 異步組件
  • Vue 組件懶加載淺析
  • [Vue.js路由懶加載[譯]](www.jianshu.com/p/abb0...

步驟

  • 1 修改組件的引用方式
// 方式一: require.ensure() const NewsList = r => require.ensure([], () => r(require('../components/news/newslist.vue')), 'news')// 方式二: import() -- 推薦 // 注意:/* webpackChunkName: "newsinfo" */ 是一個特殊的語法,表示生成js文件的名稱 const NewsInfo = () => import(/* webpackChunkName: "newsinfo" */ '../components/news/newsinfo.vue')
  • 2 修改 webpack 配置文件的output
output: {// ------添加 chunkFilename, 指定輸出js文件的名稱------chunkFilename: 'js/[name].[chunkhash].js', },

from:https://www.cnblogs.com/lvhw/p/8286544.html?

總結

以上是生活随笔為你收集整理的Vue -渐进式JavaScript框架的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

好爽又高潮了毛片免费下载 | 中文字幕人妻无码一区二区三区 | 国产亚洲精品久久久久久久 | 久久久久亚洲精品男人的天堂 | 福利一区二区三区视频在线观看 | 老头边吃奶边弄进去呻吟 | 黑人大群体交免费视频 | 无码人妻丰满熟妇区五十路百度 | 国产成人无码av片在线观看不卡 | 丁香啪啪综合成人亚洲 | 又紧又大又爽精品一区二区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 狠狠色欧美亚洲狠狠色www | 无码国内精品人妻少妇 | 精品国产国产综合精品 | 欧美人与牲动交xxxx | 欧美 日韩 亚洲 在线 | 99久久精品无码一区二区毛片 | 日本一卡2卡3卡四卡精品网站 | 日韩欧美中文字幕公布 | 亚洲日韩中文字幕在线播放 | 老熟妇乱子伦牲交视频 | 性色av无码免费一区二区三区 | 久久无码专区国产精品s | 成人亚洲精品久久久久软件 | 给我免费的视频在线观看 | 一本色道久久综合狠狠躁 | 国产精品美女久久久久av爽李琼 | 中文字幕乱码人妻无码久久 | 亚洲国产一区二区三区在线观看 | 天堂а√在线中文在线 | 日本大乳高潮视频在线观看 | 人人爽人人爽人人片av亚洲 | 久久精品女人天堂av免费观看 | 久久精品视频在线看15 | 荡女精品导航 | 免费看少妇作爱视频 | 成人动漫在线观看 | 少妇高潮喷潮久久久影院 | 国产 浪潮av性色四虎 | 一本久久伊人热热精品中文字幕 | 亚洲欧美日韩成人高清在线一区 | 77777熟女视频在线观看 а天堂中文在线官网 | 乌克兰少妇性做爰 | 亚洲国产精品成人久久蜜臀 | 性生交大片免费看l | 色综合久久久久综合一本到桃花网 | 一本色道婷婷久久欧美 | 免费看男女做好爽好硬视频 | 国产麻豆精品精东影业av网站 | 国产九九九九九九九a片 | 国产精品无码永久免费888 | 亚洲色欲色欲天天天www | 色诱久久久久综合网ywww | 欧美性黑人极品hd | 超碰97人人做人人爱少妇 | 久久人人爽人人爽人人片ⅴ | 成人无码精品1区2区3区免费看 | 2019午夜福利不卡片在线 | 老子影院午夜精品无码 | 国内丰满熟女出轨videos | 麻豆精品国产精华精华液好用吗 | 日韩人妻无码中文字幕视频 | 成人免费视频视频在线观看 免费 | 18黄暴禁片在线观看 | 99视频精品全部免费免费观看 | 久久亚洲日韩精品一区二区三区 | 亚洲欧美精品伊人久久 | 国内精品人妻无码久久久影院 | 国产熟女一区二区三区四区五区 | 亚洲精品国偷拍自产在线观看蜜桃 | 极品尤物被啪到呻吟喷水 | 亚洲一区二区三区偷拍女厕 | 精品无人区无码乱码毛片国产 | 老熟女乱子伦 | 国産精品久久久久久久 | 日韩av无码一区二区三区不卡 | 永久免费精品精品永久-夜色 | 熟妇人妻无乱码中文字幕 | 久久久久久久久888 | 婷婷丁香五月天综合东京热 | 欧美成人免费全部网站 | 欧美野外疯狂做受xxxx高潮 | 精品人人妻人人澡人人爽人人 | 一本久道久久综合婷婷五月 | 久在线观看福利视频 | 亚洲综合无码一区二区三区 | 国产精品久久久久久无码 | 暴力强奷在线播放无码 | 国产精品对白交换视频 | 日韩精品久久久肉伦网站 | 中国女人内谢69xxxxxa片 | 男女作爱免费网站 | 中文字幕无码av激情不卡 | 又大又硬又黄的免费视频 | 日本护士xxxxhd少妇 | 国产精品久久国产三级国 | 国产精品欧美成人 | 一本久道久久综合婷婷五月 | 精品国产麻豆免费人成网站 | 亚洲大尺度无码无码专区 | 欧美成人高清在线播放 | 国产一区二区三区日韩精品 | 少妇邻居内射在线 | 成在人线av无码免费 | 亚洲日本va午夜在线电影 | 成人动漫在线观看 | 曰韩少妇内射免费播放 | 亚洲国产精品美女久久久久 | 国产精品亚洲а∨无码播放麻豆 | 九九综合va免费看 | 亚洲人成无码网www | 九一九色国产 | 色综合视频一区二区三区 | 久久久精品国产sm最大网站 | 男人扒开女人内裤强吻桶进去 | 丰满少妇高潮惨叫视频 | 国产色xx群视频射精 | 亚洲欧美综合区丁香五月小说 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲人成网站免费播放 | 人人爽人人澡人人人妻 | 亚洲综合另类小说色区 | 国产人妻人伦精品1国产丝袜 | 国产精品对白交换视频 | 无码人妻丰满熟妇区毛片18 | 久久99精品国产麻豆 | 国产精品-区区久久久狼 | 国产精品久久久久久无码 | 老熟女乱子伦 | 欧美老妇交乱视频在线观看 | 88国产精品欧美一区二区三区 | 日韩精品a片一区二区三区妖精 | 久久久久久av无码免费看大片 | 纯爱无遮挡h肉动漫在线播放 | 欧美日韩久久久精品a片 | 午夜精品久久久内射近拍高清 | 国产性生交xxxxx无码 | 免费播放一区二区三区 | 国产乱人伦偷精品视频 | 男人的天堂av网站 | 成 人 网 站国产免费观看 | 国产精品怡红院永久免费 | 美女张开腿让人桶 | 爱做久久久久久 | 国产偷国产偷精品高清尤物 | 牲交欧美兽交欧美 | 国产在热线精品视频 | 国产精品久久久 | 久久精品丝袜高跟鞋 | 色情久久久av熟女人妻网站 | 日韩欧美成人免费观看 | 成人一在线视频日韩国产 | 学生妹亚洲一区二区 | 久久久久国色av免费观看性色 | 亚洲精品中文字幕 | 99er热精品视频 | 久久五月精品中文字幕 | 久久久精品成人免费观看 | 亚洲天堂2017无码中文 | 人人妻人人澡人人爽欧美一区 | 亚洲精品国偷拍自产在线麻豆 | 岛国片人妻三上悠亚 | 亚洲欧美日韩国产精品一区二区 | 欧美人妻一区二区三区 | 青草视频在线播放 | 98国产精品综合一区二区三区 | 理论片87福利理论电影 | 一本一道久久综合久久 | 最新国产麻豆aⅴ精品无码 | 久久精品人妻少妇一区二区三区 | 国产av一区二区三区最新精品 | 乌克兰少妇xxxx做受 | 欧美丰满老熟妇xxxxx性 | 免费无码的av片在线观看 | 久久久精品欧美一区二区免费 | 高潮毛片无遮挡高清免费视频 | 欧洲熟妇精品视频 | 红桃av一区二区三区在线无码av | 东京热一精品无码av | 国产熟妇高潮叫床视频播放 | 欧美高清在线精品一区 | 亚洲国产欧美在线成人 | 国产av无码专区亚洲a∨毛片 | 久久久国产一区二区三区 | 国产人妻人伦精品 | 撕开奶罩揉吮奶头视频 | 久久亚洲日韩精品一区二区三区 | 免费播放一区二区三区 | 亚洲 激情 小说 另类 欧美 | 色欲人妻aaaaaaa无码 | 免费国产成人高清在线观看网站 | 国产成人精品视频ⅴa片软件竹菊 | 久久国产精品萌白酱免费 | 激情综合激情五月俺也去 | 国产又粗又硬又大爽黄老大爷视 | 蜜臀av在线播放 久久综合激激的五月天 | 中文字幕av日韩精品一区二区 | 97夜夜澡人人爽人人喊中国片 | 亚洲の无码国产の无码步美 | 丰满岳乱妇在线观看中字无码 | 精品久久综合1区2区3区激情 | 又粗又大又硬又长又爽 | 天海翼激烈高潮到腰振不止 | 中文字幕色婷婷在线视频 | 欧美成人家庭影院 | 性欧美疯狂xxxxbbbb | av无码不卡在线观看免费 | 亚洲精品国产a久久久久久 | 国产激情无码一区二区app | 亚洲色在线无码国产精品不卡 | 全黄性性激高免费视频 | 夜夜夜高潮夜夜爽夜夜爰爰 | 免费观看的无遮挡av | 日本精品人妻无码免费大全 | 亚洲精品成人av在线 | 四虎永久在线精品免费网址 | 久久精品国产日本波多野结衣 | 波多野结衣av在线观看 | www成人国产高清内射 | 乱码av麻豆丝袜熟女系列 | 欧美喷潮久久久xxxxx | 国产成人久久精品流白浆 | 美女毛片一区二区三区四区 | 国内综合精品午夜久久资源 | 中文字幕无码日韩欧毛 | 色综合久久久久综合一本到桃花网 | 人人澡人摸人人添 | 国产精品久久久久久亚洲毛片 | 国产综合在线观看 | 爽爽影院免费观看 | 免费无码的av片在线观看 | 久久亚洲精品中文字幕无男同 | 色综合久久网 | 久久99精品国产.久久久久 | 亚洲va中文字幕无码久久不卡 | aa片在线观看视频在线播放 | 人妻夜夜爽天天爽三区 | 九一九色国产 | 国产深夜福利视频在线 | 亚洲无人区一区二区三区 | 国产内射老熟女aaaa | 麻豆人妻少妇精品无码专区 | 色婷婷久久一区二区三区麻豆 | 风流少妇按摩来高潮 | 国产精品嫩草久久久久 | 天天av天天av天天透 | 国产97色在线 | 免 | 国产精品久久久久久久9999 | 色情久久久av熟女人妻网站 | 色欲久久久天天天综合网精品 | 搡女人真爽免费视频大全 | www一区二区www免费 | 欧美日韩久久久精品a片 | 自拍偷自拍亚洲精品被多人伦好爽 | 色一情一乱一伦一视频免费看 | 亚洲综合久久一区二区 | 帮老师解开蕾丝奶罩吸乳网站 | 精品国产成人一区二区三区 | 国产午夜精品一区二区三区嫩草 | 一个人看的视频www在线 | 久久精品女人天堂av免费观看 | 久久天天躁夜夜躁狠狠 | 久久久精品456亚洲影院 | 5858s亚洲色大成网站www | 亚洲熟熟妇xxxx | 日韩人妻无码中文字幕视频 | 精品偷自拍另类在线观看 | 国产精品久久久久久亚洲毛片 | 亚洲精品无码人妻无码 | 无码人妻黑人中文字幕 | 狠狠色丁香久久婷婷综合五月 | 国产成人无码a区在线观看视频app | 丝袜美腿亚洲一区二区 | 精品无人区无码乱码毛片国产 | 67194成是人免费无码 | 麻豆蜜桃av蜜臀av色欲av | a片在线免费观看 | 九九综合va免费看 | 捆绑白丝粉色jk震动捧喷白浆 | 成人试看120秒体验区 | 亚洲色偷偷偷综合网 | 国产精品毛多多水多 | 国内精品人妻无码久久久影院 | 18黄暴禁片在线观看 | 中文字幕无码日韩欧毛 | 国产成人一区二区三区在线观看 | 亚洲中文字幕无码中字 | 国产莉萝无码av在线播放 | 欧美日韩视频无码一区二区三 | 国产亚洲视频中文字幕97精品 | 蜜桃av抽搐高潮一区二区 | 无码av岛国片在线播放 | 色综合久久网 | 久久午夜夜伦鲁鲁片无码免费 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 久久精品人人做人人综合 | 东京一本一道一二三区 | 帮老师解开蕾丝奶罩吸乳网站 | 99精品视频在线观看免费 | 精品国产麻豆免费人成网站 | 秋霞特色aa大片 | 久久久婷婷五月亚洲97号色 | 牲欲强的熟妇农村老妇女视频 | 无码精品国产va在线观看dvd | 亚洲aⅴ无码成人网站国产app | 中文精品无码中文字幕无码专区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 欧美日韩人成综合在线播放 | 国产精品久久久久久亚洲影视内衣 | 亚洲熟妇色xxxxx亚洲 | 国产在线精品一区二区高清不卡 | 牲交欧美兽交欧美 | 精品成在人线av无码免费看 | 久久99精品久久久久久动态图 | 性色av无码免费一区二区三区 | 性做久久久久久久免费看 | 国产亚洲精品久久久闺蜜 | 国产做国产爱免费视频 | 爱做久久久久久 | 色欲久久久天天天综合网精品 | 精品无码一区二区三区爱欲 | 国产绳艺sm调教室论坛 | 扒开双腿疯狂进出爽爽爽视频 | 亚洲色偷偷偷综合网 | 丰满肥臀大屁股熟妇激情视频 | 人人妻人人澡人人爽欧美一区 | 精品久久综合1区2区3区激情 | 久久国产36精品色熟妇 | 亚洲欧美日韩成人高清在线一区 | 亚洲精品久久久久久久久久久 | 人人超人人超碰超国产 | 国产成人无码专区 | 国产欧美亚洲精品a | 亚洲色欲久久久综合网东京热 | 精品国产一区二区三区av 性色 | 国产麻豆精品精东影业av网站 | 亚洲精品久久久久avwww潮水 | 国产超碰人人爽人人做人人添 | 精品国产精品久久一区免费式 | 国产肉丝袜在线观看 | 日韩人妻系列无码专区 | 色偷偷人人澡人人爽人人模 | 国产小呦泬泬99精品 | 国产精品久久久 | 天天躁夜夜躁狠狠是什么心态 | 在线观看国产一区二区三区 | 97资源共享在线视频 | 中文字幕日韩精品一区二区三区 | 日日噜噜噜噜夜夜爽亚洲精品 | 久久精品人人做人人综合试看 | www国产亚洲精品久久网站 | 又湿又紧又大又爽a视频国产 | 国产乱人伦偷精品视频 | 97无码免费人妻超级碰碰夜夜 | 一个人免费观看的www视频 | 国产成人精品一区二区在线小狼 | 国产一区二区三区日韩精品 | 领导边摸边吃奶边做爽在线观看 | 国产午夜福利亚洲第一 | 国产亚洲精品久久久久久久久动漫 | 最近免费中文字幕中文高清百度 | 高潮喷水的毛片 | 亚洲s码欧洲m码国产av | 国产色视频一区二区三区 | 奇米影视7777久久精品人人爽 | 午夜精品久久久久久久久 | 亚洲国产精品毛片av不卡在线 | 国语自产偷拍精品视频偷 | 四虎国产精品一区二区 | 亚洲男人av香蕉爽爽爽爽 | 四十如虎的丰满熟妇啪啪 | 欧美阿v高清资源不卡在线播放 | 亚洲综合另类小说色区 | 久久精品国产亚洲精品 | 99精品久久毛片a片 | 欧美精品一区二区精品久久 | 亚洲精品一区二区三区四区五区 | 日韩精品乱码av一区二区 | 无码人妻精品一区二区三区不卡 | 国产亲子乱弄免费视频 | 国色天香社区在线视频 | 欧美黑人性暴力猛交喷水 | 午夜无码人妻av大片色欲 | 内射老妇bbwx0c0ck | 国产人妻人伦精品1国产丝袜 | 国产三级久久久精品麻豆三级 | 国产成人亚洲综合无码 | 亚洲色偷偷偷综合网 | 一区二区三区高清视频一 | 人人妻在人人 | 乱人伦人妻中文字幕无码久久网 | 欧美丰满老熟妇xxxxx性 | 久久久久人妻一区精品色欧美 | 又紧又大又爽精品一区二区 | 欧美精品无码一区二区三区 | 亚洲综合久久一区二区 | 中文字幕无码免费久久9一区9 | 免费国产成人高清在线观看网站 | 国产极品美女高潮无套在线观看 | 日韩人妻无码中文字幕视频 | 老子影院午夜精品无码 | 人人澡人人妻人人爽人人蜜桃 | 中文字幕色婷婷在线视频 | 国产一区二区三区四区五区加勒比 | 内射爽无广熟女亚洲 | 亚洲爆乳精品无码一区二区三区 | 亚洲性无码av中文字幕 | 四虎4hu永久免费 | 国产成人综合美国十次 | 精品久久久久久人妻无码中文字幕 | 秋霞特色aa大片 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 日韩亚洲欧美精品综合 | 色一情一乱一伦一视频免费看 | 国产97人人超碰caoprom | 女人被男人躁得好爽免费视频 | 久久久久久九九精品久 | 精品国精品国产自在久国产87 | 暴力强奷在线播放无码 | 亚洲精品久久久久avwww潮水 | 免费观看的无遮挡av | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产亚av手机在线观看 | 亚洲乱亚洲乱妇50p | 一二三四在线观看免费视频 | 日韩人妻少妇一区二区三区 | 久久久久国色av免费观看性色 | 日韩成人一区二区三区在线观看 | 亚洲一区二区三区含羞草 | 少妇愉情理伦片bd | 在线观看国产午夜福利片 | 97夜夜澡人人爽人人喊中国片 | 欧美三级a做爰在线观看 | 人妻中文无码久热丝袜 | 激情爆乳一区二区三区 | 亚洲成a人片在线观看无码 | 精品国产乱码久久久久乱码 | 中文久久乱码一区二区 | 亚洲综合无码一区二区三区 | 欧美丰满少妇xxxx性 | 77777熟女视频在线观看 а天堂中文在线官网 | 欧美老熟妇乱xxxxx | 性生交大片免费看女人按摩摩 | 波多野结衣aⅴ在线 | 亚洲成a人一区二区三区 | 3d动漫精品啪啪一区二区中 | 激情综合激情五月俺也去 | 亚洲小说图区综合在线 | 日本熟妇浓毛 | 久久久久国色av免费观看性色 | 在线欧美精品一区二区三区 | 国产精品无码永久免费888 | 久久无码专区国产精品s | 国产精品香蕉在线观看 | 色综合视频一区二区三区 | 亚洲综合精品香蕉久久网 | 1000部夫妻午夜免费 | 久久久久se色偷偷亚洲精品av | 小泽玛莉亚一区二区视频在线 | 日韩无码专区 | 国产午夜福利100集发布 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲日韩中文字幕在线播放 | 国产艳妇av在线观看果冻传媒 | 日本www一道久久久免费榴莲 | 在教室伦流澡到高潮hnp视频 | 国产成人无码av一区二区 | 亚洲日韩av一区二区三区四区 | 欧美乱妇无乱码大黄a片 | 亚洲色www成人永久网址 | 亚洲日韩av一区二区三区四区 | 麻豆md0077饥渴少妇 | 日本护士毛茸茸高潮 | 双乳奶水饱满少妇呻吟 | 国内精品人妻无码久久久影院蜜桃 | 久久综合激激的五月天 | 国产成人无码av一区二区 | a国产一区二区免费入口 | www国产亚洲精品久久网站 | 夜夜影院未满十八勿进 | 久久久久99精品国产片 | 国产精品-区区久久久狼 | 97色伦图片97综合影院 | 1000部啪啪未满十八勿入下载 | 色婷婷香蕉在线一区二区 | 免费国产成人高清在线观看网站 | 久久久久se色偷偷亚洲精品av | 国产亚洲tv在线观看 | 日本va欧美va欧美va精品 | 亚洲 高清 成人 动漫 | 色五月丁香五月综合五月 | 免费乱码人妻系列无码专区 | av无码电影一区二区三区 | 日韩人妻系列无码专区 | 午夜精品一区二区三区的区别 | 国产办公室秘书无码精品99 | 无码纯肉视频在线观看 | 亚洲熟悉妇女xxx妇女av | 波多野结衣一区二区三区av免费 | 欧美国产日产一区二区 | 国产午夜亚洲精品不卡 | 麻豆精产国品 | 欧洲美熟女乱又伦 | 蜜臀aⅴ国产精品久久久国产老师 | 成人精品天堂一区二区三区 | 久久精品丝袜高跟鞋 | 国产精品99久久精品爆乳 | 午夜成人1000部免费视频 | 国产精品久久国产精品99 | 成人亚洲精品久久久久 | 日韩少妇白浆无码系列 | 狠狠色丁香久久婷婷综合五月 | 又紧又大又爽精品一区二区 | 美女黄网站人色视频免费国产 | 亚洲日韩精品欧美一区二区 | 少妇无码av无码专区在线观看 | 无套内谢老熟女 | 亚洲精品国产品国语在线观看 | 东京热一精品无码av | √8天堂资源地址中文在线 | 亚洲欧美国产精品久久 | 精品人妻中文字幕有码在线 | 精品久久综合1区2区3区激情 | 天堂无码人妻精品一区二区三区 | 任你躁国产自任一区二区三区 | 麻豆果冻传媒2021精品传媒一区下载 | 兔费看少妇性l交大片免费 | 精品久久久久香蕉网 | 日韩人妻无码一区二区三区久久99 | 精品无码一区二区三区的天堂 | 国产suv精品一区二区五 | 国产高潮视频在线观看 | 精品无码一区二区三区的天堂 | 夜夜躁日日躁狠狠久久av | 麻花豆传媒剧国产免费mv在线 | 欧洲vodafone精品性 | 国产69精品久久久久app下载 | 国产口爆吞精在线视频 | 亚洲国产精品一区二区第一页 | 国内精品久久久久久中文字幕 | 永久黄网站色视频免费直播 | 高中生自慰www网站 | 色老头在线一区二区三区 | 国产九九九九九九九a片 | 色欲av亚洲一区无码少妇 | 波多野结衣一区二区三区av免费 | 久久久久久久久蜜桃 | 成在人线av无码免观看麻豆 | 亚洲成av人综合在线观看 | 精品人妻av区 | 永久免费精品精品永久-夜色 | 国产成人av免费观看 | 婷婷丁香五月天综合东京热 | 美女极度色诱视频国产 | 十八禁视频网站在线观看 | 女高中生第一次破苞av | 色婷婷综合激情综在线播放 | 又粗又大又硬又长又爽 | 国产成人无码午夜视频在线观看 | 天堂无码人妻精品一区二区三区 | 久久久久se色偷偷亚洲精品av | 荫蒂被男人添的好舒服爽免费视频 | 亚洲熟妇自偷自拍另类 | 国产精品久久久久9999小说 | 亚拍精品一区二区三区探花 | 性欧美熟妇videofreesex | 黑人巨大精品欧美黑寡妇 | 老熟妇仑乱视频一区二区 | 国产精品.xx视频.xxtv | 精品久久8x国产免费观看 | 日日鲁鲁鲁夜夜爽爽狠狠 | 天堂久久天堂av色综合 | 欧美精品国产综合久久 | 丰满少妇高潮惨叫视频 | a片在线免费观看 | 欧美人妻一区二区三区 | 无码一区二区三区在线观看 | 日韩亚洲欧美中文高清在线 | 色窝窝无码一区二区三区色欲 | 国产情侣作爱视频免费观看 | 色综合久久久无码网中文 | 波多野结衣av在线观看 | 综合人妻久久一区二区精品 | 伦伦影院午夜理论片 | 自拍偷自拍亚洲精品被多人伦好爽 | 久久精品人人做人人综合试看 | 伊人久久婷婷五月综合97色 | 国内丰满熟女出轨videos | 亚洲精品久久久久久久久久久 | 人妻互换免费中文字幕 | 国产舌乚八伦偷品w中 | 亚洲国产欧美国产综合一区 | 狂野欧美激情性xxxx | 中文字幕久久久久人妻 | 欧美35页视频在线观看 | 午夜时刻免费入口 | 欧美日韩一区二区三区自拍 | 国产精品亚洲а∨无码播放麻豆 | 人妻中文无码久热丝袜 | 亚洲爆乳无码专区 | 无码人中文字幕 | 99精品无人区乱码1区2区3区 | 无码人妻精品一区二区三区下载 | 婷婷色婷婷开心五月四房播播 | 免费观看又污又黄的网站 | 日本欧美一区二区三区乱码 | 熟妇激情内射com | 日韩人妻无码一区二区三区久久99 | 成 人 免费观看网站 | 久久成人a毛片免费观看网站 | 亚洲爆乳大丰满无码专区 | 亚洲 日韩 欧美 成人 在线观看 | 国产成人综合在线女婷五月99播放 | 少妇无套内谢久久久久 | 窝窝午夜理论片影院 | 国产熟女一区二区三区四区五区 | 日本护士毛茸茸高潮 | 丝袜人妻一区二区三区 | 狠狠躁日日躁夜夜躁2020 | 亚洲日韩av一区二区三区中文 | 久久久久久久女国产乱让韩 | 一本久道久久综合婷婷五月 | 99er热精品视频 | 欧美黑人巨大xxxxx | 亚洲成a人片在线观看无码 | 全黄性性激高免费视频 | 麻花豆传媒剧国产免费mv在线 | 久久久国产一区二区三区 | 少妇邻居内射在线 | av香港经典三级级 在线 | 97精品国产97久久久久久免费 | 亚洲精品欧美二区三区中文字幕 | 国产内射爽爽大片视频社区在线 | 无套内谢的新婚少妇国语播放 | 日本在线高清不卡免费播放 | 日本爽爽爽爽爽爽在线观看免 | 樱花草在线播放免费中文 | 国产精品理论片在线观看 | 精品国偷自产在线视频 | 亚洲色大成网站www | 久久99精品久久久久久动态图 | 亚洲精品美女久久久久久久 | 俄罗斯老熟妇色xxxx | 午夜精品久久久久久久久 | 国产成人无码区免费内射一片色欲 | 97人妻精品一区二区三区 | 国产精品久久久久久亚洲毛片 | 草草网站影院白丝内射 | 4hu四虎永久在线观看 | 亚洲一区二区三区无码久久 | 精品无码国产一区二区三区av | 乱码av麻豆丝袜熟女系列 | 男女猛烈xx00免费视频试看 | 国产精品久久久久久亚洲毛片 | 国产极品美女高潮无套在线观看 | 熟妇人妻无码xxx视频 | 99久久人妻精品免费二区 | 国产深夜福利视频在线 | 国产精品-区区久久久狼 | 色婷婷综合激情综在线播放 | 亚洲精品美女久久久久久久 | 日产精品高潮呻吟av久久 | 天下第一社区视频www日本 | 久久精品国产日本波多野结衣 | 丰满人妻精品国产99aⅴ | 久久国内精品自在自线 | 免费观看又污又黄的网站 | 人人澡人人妻人人爽人人蜜桃 | 蜜桃视频韩日免费播放 | 国产精品美女久久久久av爽李琼 | 午夜精品久久久久久久 | 永久免费观看国产裸体美女 | 亚洲成a人片在线观看无码 | 亚洲精品久久久久久一区二区 | 亚洲熟妇色xxxxx亚洲 | 欧美人妻一区二区三区 | 99久久精品午夜一区二区 | 久久人人爽人人爽人人片av高清 | 日本一区二区三区免费高清 | 麻豆精品国产精华精华液好用吗 | 无码福利日韩神码福利片 | 久久99热只有频精品8 | 初尝人妻少妇中文字幕 | 精品久久久无码中文字幕 | 亚洲精品成人av在线 | 樱花草在线社区www | 日本精品久久久久中文字幕 | 桃花色综合影院 | 欧美日韩精品 | 久久久久亚洲精品男人的天堂 | 日韩少妇白浆无码系列 | 亚洲精品久久久久avwww潮水 | 丰满少妇高潮惨叫视频 | 亚洲精品欧美二区三区中文字幕 | 性生交大片免费看女人按摩摩 | 男人扒开女人内裤强吻桶进去 | 久久婷婷五月综合色国产香蕉 | 久久综合激激的五月天 | 久久综合九色综合欧美狠狠 | 无码精品人妻一区二区三区av | 国产精品鲁鲁鲁 | 大肉大捧一进一出好爽视频 | 国产麻豆精品精东影业av网站 | 日本精品人妻无码免费大全 | 久久久久亚洲精品中文字幕 | 国产偷国产偷精品高清尤物 | 欧美老妇交乱视频在线观看 | 久久久久国色av免费观看性色 | 精品夜夜澡人妻无码av蜜桃 | 日韩精品乱码av一区二区 | 国产精品香蕉在线观看 | 精品厕所偷拍各类美女tp嘘嘘 | 日韩欧美成人免费观看 | 男人扒开女人内裤强吻桶进去 | 少妇高潮一区二区三区99 | 爱做久久久久久 | 日本精品高清一区二区 | 亚洲经典千人经典日产 | 欧美亚洲日韩国产人成在线播放 | 久久久久久av无码免费看大片 | 丰满人妻翻云覆雨呻吟视频 | 老熟妇乱子伦牲交视频 | 中国大陆精品视频xxxx | 国产午夜亚洲精品不卡下载 | 中文字幕av伊人av无码av | 黑人巨大精品欧美一区二区 | 成在人线av无码免费 | 麻豆精品国产精华精华液好用吗 | 日本一卡2卡3卡四卡精品网站 | 久久久久亚洲精品男人的天堂 | 久久无码专区国产精品s | 99久久人妻精品免费一区 | 性做久久久久久久久 | 又粗又大又硬又长又爽 | 久久国产36精品色熟妇 | 色噜噜亚洲男人的天堂 | 日韩精品久久久肉伦网站 | 黑人粗大猛烈进出高潮视频 | 国产亚洲日韩欧美另类第八页 | 中文精品久久久久人妻不卡 | 亚洲精品久久久久久久久久久 | www国产精品内射老师 | 中文字幕无码av激情不卡 | 久激情内射婷内射蜜桃人妖 | 亚洲人成网站免费播放 | 久久精品国产一区二区三区 | 中文字幕乱码亚洲无线三区 | 图片小说视频一区二区 | 日本va欧美va欧美va精品 | 爽爽影院免费观看 | 久久亚洲日韩精品一区二区三区 | 久青草影院在线观看国产 | 久久久久99精品成人片 | 97人妻精品一区二区三区 | 欧美激情综合亚洲一二区 | 在线看片无码永久免费视频 | 四虎4hu永久免费 | 久久久国产一区二区三区 | 国产一区二区三区日韩精品 | 久久久精品人妻久久影视 | 婷婷综合久久中文字幕蜜桃三电影 | 玩弄少妇高潮ⅹxxxyw | 在线观看国产午夜福利片 | 成人一在线视频日韩国产 | 亚洲成av人片在线观看无码不卡 | 性色欲情网站iwww九文堂 | 久久综合给久久狠狠97色 | 人人妻人人澡人人爽人人精品浪潮 | 亚洲日本在线电影 | 无码国内精品人妻少妇 | 无人区乱码一区二区三区 | 77777熟女视频在线观看 а天堂中文在线官网 | 亚洲国产精品无码一区二区三区 | 亚洲成av人片在线观看无码不卡 | 亚洲男女内射在线播放 | 欧美丰满熟妇xxxx性ppx人交 | 欧美人与禽zoz0性伦交 | 久久久久成人精品免费播放动漫 | 亚洲欧洲无卡二区视頻 | 欧美大屁股xxxxhd黑色 | 性色欲网站人妻丰满中文久久不卡 | 国产超碰人人爽人人做人人添 | 亚洲s码欧洲m码国产av | 精品国产成人一区二区三区 | 欧美熟妇另类久久久久久多毛 | 亚洲国产精品久久人人爱 | 亚洲人成无码网www | 窝窝午夜理论片影院 | 少妇激情av一区二区 | 人人妻人人澡人人爽人人精品浪潮 | 日韩人妻无码中文字幕视频 | 亚洲熟熟妇xxxx | 俺去俺来也www色官网 | 在线天堂新版最新版在线8 | 国产成人午夜福利在线播放 | 国产精品久久久午夜夜伦鲁鲁 | 午夜丰满少妇性开放视频 | 天天拍夜夜添久久精品 | 国产9 9在线 | 中文 | 亚洲欧美日韩国产精品一区二区 | 青草青草久热国产精品 | 欧美日本免费一区二区三区 | 熟妇女人妻丰满少妇中文字幕 | 国产人妖乱国产精品人妖 | 亚洲国产欧美在线成人 | 无码人妻黑人中文字幕 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲欧美色中文字幕在线 | 欧美喷潮久久久xxxxx | 亚洲中文字幕无码中文字在线 | 国产在热线精品视频 | 国产精品视频免费播放 | 特黄特色大片免费播放器图片 | 国产真实伦对白全集 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 亚洲 日韩 欧美 成人 在线观看 | 中文字幕无码免费久久9一区9 | 久久国产精品二国产精品 | 久久婷婷五月综合色国产香蕉 | 欧美 丝袜 自拍 制服 另类 | 大胆欧美熟妇xx | 中国大陆精品视频xxxx | 免费无码av一区二区 | 国产精品高潮呻吟av久久 | 中文字幕人成乱码熟女app | 女人被男人躁得好爽免费视频 | 一本大道久久东京热无码av | 国产办公室秘书无码精品99 | 色狠狠av一区二区三区 | 激情内射日本一区二区三区 | 国产人妖乱国产精品人妖 | 亚洲 高清 成人 动漫 | 午夜性刺激在线视频免费 | 国产又粗又硬又大爽黄老大爷视 | 亚洲精品一区三区三区在线观看 | 国产精品久久久久久亚洲毛片 | 无码国产激情在线观看 | 久久综合九色综合欧美狠狠 | 国产免费无码一区二区视频 | 波多野结衣乳巨码无在线观看 | 国产精品久久久久久亚洲影视内衣 | 波多野结衣av一区二区全免费观看 | 国产人妖乱国产精品人妖 | 色五月五月丁香亚洲综合网 | 人妻夜夜爽天天爽三区 | 在线精品亚洲一区二区 | 国产无套粉嫩白浆在线 | 性开放的女人aaa片 | 亚洲欧美日韩综合久久久 | 好男人www社区 | 一本大道伊人av久久综合 | 亚洲精品午夜无码电影网 | 国产精品久久久久久无码 | 曰本女人与公拘交酡免费视频 | 亚洲熟妇色xxxxx欧美老妇 | 国产精品亚洲lv粉色 | 超碰97人人做人人爱少妇 | 国产午夜福利亚洲第一 | 久久午夜夜伦鲁鲁片无码免费 | 性生交大片免费看女人按摩摩 | 漂亮人妻洗澡被公强 日日躁 | 无码人妻丰满熟妇区毛片18 | 精品无人国产偷自产在线 | 一本色道久久综合狠狠躁 | 亚欧洲精品在线视频免费观看 | 鲁鲁鲁爽爽爽在线视频观看 | 久久国产精品二国产精品 | 无码人妻av免费一区二区三区 | av在线亚洲欧洲日产一区二区 | 国产又粗又硬又大爽黄老大爷视 | 扒开双腿吃奶呻吟做受视频 | 久久久国产精品无码免费专区 | 欧美日韩人成综合在线播放 | 欧美兽交xxxx×视频 | 免费无码午夜福利片69 | 久久精品人人做人人综合试看 | 欧美性生交xxxxx久久久 | 中文字幕人妻无码一区二区三区 | 午夜福利一区二区三区在线观看 | 又黄又爽又色的视频 | 夜精品a片一区二区三区无码白浆 | 亚无码乱人伦一区二区 | 欧美日韩人成综合在线播放 | 在线观看国产一区二区三区 | 又大又紧又粉嫩18p少妇 | av无码电影一区二区三区 | 内射爽无广熟女亚洲 | 丰满少妇弄高潮了www | 成在人线av无码免费 | 亚洲人成网站色7799 | 国产免费久久精品国产传媒 | 好男人www社区 | 国产精品.xx视频.xxtv | 日本在线高清不卡免费播放 | 国产精品久久久一区二区三区 | 学生妹亚洲一区二区 | 99久久精品日本一区二区免费 | 日本一区二区更新不卡 | 宝宝好涨水快流出来免费视频 | 无码国产色欲xxxxx视频 | 无码纯肉视频在线观看 | 无码人妻久久一区二区三区不卡 | 欧美老妇与禽交 | 日韩 欧美 动漫 国产 制服 | 久久精品国产一区二区三区肥胖 | 又粗又大又硬又长又爽 | 色老头在线一区二区三区 | 亚洲欧洲日本综合aⅴ在线 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 99视频精品全部免费免费观看 | 一区二区三区高清视频一 | 人人澡人人妻人人爽人人蜜桃 | √天堂中文官网8在线 | 国产精品久久久 | 亚洲熟妇色xxxxx欧美老妇y | 中国大陆精品视频xxxx | 国产极品美女高潮无套在线观看 | 欧美熟妇另类久久久久久不卡 | 亚洲 a v无 码免 费 成 人 a v | 国产成人精品久久亚洲高清不卡 | 欧美日韩久久久精品a片 | 久久无码专区国产精品s | 麻豆md0077饥渴少妇 | 久久国产精品二国产精品 | 特黄特色大片免费播放器图片 | 草草网站影院白丝内射 | 国产亚洲视频中文字幕97精品 | 天天摸天天碰天天添 | 亚洲精品午夜国产va久久成人 | 色老头在线一区二区三区 | 久久熟妇人妻午夜寂寞影院 | 国产69精品久久久久app下载 | 欧美精品在线观看 | 国产va免费精品观看 | 色婷婷欧美在线播放内射 | 老司机亚洲精品影院 | 少妇久久久久久人妻无码 | 国产成人无码一二三区视频 | 国产精品无码mv在线观看 | 7777奇米四色成人眼影 | 久久精品99久久香蕉国产色戒 | 亚洲欧美色中文字幕在线 | 日本护士xxxxhd少妇 | 人妻无码αv中文字幕久久琪琪布 | 国产激情精品一区二区三区 | 久久久亚洲欧洲日产国码αv | 国产明星裸体无码xxxx视频 | 天堂а√在线中文在线 | 国产精品久久久久久亚洲毛片 | 国产综合在线观看 | 国产精品久久久久无码av色戒 | 伊人久久大香线蕉午夜 | 国产卡一卡二卡三 | 精品国产av色一区二区深夜久久 | 狠狠躁日日躁夜夜躁2020 | 婷婷六月久久综合丁香 | 极品尤物被啪到呻吟喷水 | а√资源新版在线天堂 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 久久精品99久久香蕉国产色戒 | 国产精品毛多多水多 | 久久久久久国产精品无码下载 | 中文字幕日韩精品一区二区三区 | 午夜时刻免费入口 | 俺去俺来也在线www色官网 | 亚洲成a人片在线观看无码3d | 99久久人妻精品免费二区 | 亚洲中文字幕在线无码一区二区 | 欧美freesex黑人又粗又大 | 性做久久久久久久久 | 欧洲vodafone精品性 | 久久精品国产亚洲精品 | 亚洲の无码国产の无码影院 | 日本精品人妻无码免费大全 | 色欲综合久久中文字幕网 | 欧美成人午夜精品久久久 | 老熟女乱子伦 | 波多野结衣av在线观看 | 亚洲中文字幕va福利 | 日韩人妻少妇一区二区三区 | 少妇一晚三次一区二区三区 | 国产在线精品一区二区高清不卡 | 四虎影视成人永久免费观看视频 | 亚洲色大成网站www | 精品亚洲成av人在线观看 | 老熟妇仑乱视频一区二区 | 欧美性生交xxxxx久久久 | 成人一区二区免费视频 | 亚洲国产精品久久人人爱 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲熟妇色xxxxx欧美老妇 | 国产av一区二区三区最新精品 | 亚洲精品一区国产 | 日本免费一区二区三区最新 | 精品无码国产一区二区三区av | 亚洲熟女一区二区三区 | 波多野结衣一区二区三区av免费 | 精品国产国产综合精品 | 秋霞成人午夜鲁丝一区二区三区 | 国产精品手机免费 | 欧美亚洲国产一区二区三区 | 十八禁视频网站在线观看 | 亚洲国产高清在线观看视频 | 东京热一精品无码av | 一二三四在线观看免费视频 | 夜先锋av资源网站 | 欧美人与牲动交xxxx | 国产精品怡红院永久免费 | 国产精品美女久久久久av爽李琼 | 亚洲欧洲中文日韩av乱码 | 国产高清不卡无码视频 | 一个人看的视频www在线 | 日韩人妻少妇一区二区三区 | 色综合久久久无码网中文 | 国产精品a成v人在线播放 | 荫蒂添的好舒服视频囗交 | 久久精品国产精品国产精品污 | 久久久成人毛片无码 | 久久成人a毛片免费观看网站 | 无码福利日韩神码福利片 | 一本久久伊人热热精品中文字幕 | 男人扒开女人内裤强吻桶进去 | 大地资源网第二页免费观看 | 一本久道久久综合狠狠爱 | 麻豆蜜桃av蜜臀av色欲av | 亚洲熟妇自偷自拍另类 | 东京热无码av男人的天堂 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲欧美日韩成人高清在线一区 | 日韩人妻无码一区二区三区久久99 | 人人妻人人澡人人爽欧美精品 | 国产特级毛片aaaaaaa高清 | 中文字幕人妻无码一区二区三区 | 欧洲熟妇精品视频 | 久久精品人妻少妇一区二区三区 | 无套内谢的新婚少妇国语播放 | 久久精品视频在线看15 | 亚洲精品国产品国语在线观看 | 国产内射爽爽大片视频社区在线 | 国产精品毛多多水多 | 人人超人人超碰超国产 | 亚洲精品久久久久avwww潮水 | 色婷婷av一区二区三区之红樱桃 | 国产乱人偷精品人妻a片 | 99久久精品无码一区二区毛片 | 国产av久久久久精东av | 成人精品天堂一区二区三区 | 免费无码一区二区三区蜜桃大 | 亚洲人成人无码网www国产 | 一本久久a久久精品vr综合 | 国产精品香蕉在线观看 | 国产精品久久久久影院嫩草 | 亚洲一区二区观看播放 | 欧美 日韩 人妻 高清 中文 | 欧美老熟妇乱xxxxx | 内射爽无广熟女亚洲 | 老熟妇仑乱视频一区二区 | 国语自产偷拍精品视频偷 | 激情内射亚州一区二区三区爱妻 | 天天躁日日躁狠狠躁免费麻豆 | 呦交小u女精品视频 | 18禁黄网站男男禁片免费观看 | 成人影院yy111111在线观看 | 人人超人人超碰超国产 | 2019nv天堂香蕉在线观看 | 啦啦啦www在线观看免费视频 | 国产人妻精品一区二区三区不卡 | 亚洲另类伦春色综合小说 | 久久久久久久女国产乱让韩 | 国产成人综合在线女婷五月99播放 | 狠狠cao日日穞夜夜穞av | 76少妇精品导航 | 人人澡人人透人人爽 | 色综合久久88色综合天天 | 国产精品99爱免费视频 | 国内老熟妇对白xxxxhd | 又大又硬又黄的免费视频 | 天天拍夜夜添久久精品大 | 欧美阿v高清资源不卡在线播放 | 无码人妻少妇伦在线电影 | 久久精品国产大片免费观看 | 日本一卡2卡3卡四卡精品网站 | 国产精品无码成人午夜电影 | 18禁止看的免费污网站 | 久久99精品久久久久久 | 成人试看120秒体验区 | 亚洲一区二区观看播放 | 国产色精品久久人妻 | 国产网红无码精品视频 | 久在线观看福利视频 | 未满小14洗澡无码视频网站 | 又湿又紧又大又爽a视频国产 | 沈阳熟女露脸对白视频 | 草草网站影院白丝内射 | 国产成人无码午夜视频在线观看 | 亚洲阿v天堂在线 | 国产性生交xxxxx无码 | 综合网日日天干夜夜久久 | 少妇一晚三次一区二区三区 | 中文字幕中文有码在线 | 色五月五月丁香亚洲综合网 | 国产熟妇另类久久久久 | 亚洲精品国产第一综合99久久 | 国产做国产爱免费视频 | 少妇无码一区二区二三区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产综合久久久久鬼色 | 亚洲综合无码久久精品综合 | 天天综合网天天综合色 | 久久人人爽人人爽人人片ⅴ | 天天爽夜夜爽夜夜爽 | 日本爽爽爽爽爽爽在线观看免 | 国语精品一区二区三区 | 波多野结衣一区二区三区av免费 | 人妻少妇被猛烈进入中文字幕 | 蜜桃无码一区二区三区 | 亚洲国产欧美在线成人 | 无码午夜成人1000部免费视频 | 激情国产av做激情国产爱 | 国产精品人人爽人人做我的可爱 | 亚洲欧美日韩综合久久久 | 久久国语露脸国产精品电影 | 西西人体www44rt大胆高清 | 国产偷抇久久精品a片69 | 精品国产一区二区三区av 性色 | 波多野结衣 黑人 | 无码人妻少妇伦在线电影 | av无码电影一区二区三区 | 亚洲色www成人永久网址 | 国产成人人人97超碰超爽8 | 一个人免费观看的www视频 | 国产无遮挡吃胸膜奶免费看 | 久久综合激激的五月天 | 久久97精品久久久久久久不卡 | 久久97精品久久久久久久不卡 | 色诱久久久久综合网ywww | 熟妇人妻无乱码中文字幕 | 亚洲午夜久久久影院 | 国产人妻精品一区二区三区不卡 | 精品人妻人人做人人爽夜夜爽 | 对白脏话肉麻粗话av | 国产办公室秘书无码精品99 | 中文字幕人妻无码一夲道 | 999久久久国产精品消防器材 | 色欲av亚洲一区无码少妇 | 午夜无码人妻av大片色欲 | 欧美熟妇另类久久久久久多毛 | 曰韩无码二三区中文字幕 | 亚洲无人区一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 亚洲欧洲日本无在线码 | 九月婷婷人人澡人人添人人爽 | 免费观看又污又黄的网站 | 久久久久se色偷偷亚洲精品av | 亚洲精品一区二区三区在线 | 无遮无挡爽爽免费视频 | 亚洲精品国偷拍自产在线麻豆 | 最新版天堂资源中文官网 | 55夜色66夜色国产精品视频 | 日日麻批免费40分钟无码 | 少妇性l交大片欧洲热妇乱xxx | 国产精品18久久久久久麻辣 | 无码人妻丰满熟妇区五十路百度 | 偷窥日本少妇撒尿chinese | 亚洲欧美日韩国产精品一区二区 | 久热国产vs视频在线观看 | 无码人妻久久一区二区三区不卡 | 久久zyz资源站无码中文动漫 | 又大又硬又黄的免费视频 | 欧美变态另类xxxx | 性色欲网站人妻丰满中文久久不卡 | 亚洲一区二区三区国产精华液 | 一本一道久久综合久久 | 亚洲色大成网站www国产 | 玩弄中年熟妇正在播放 | 欧美老人巨大xxxx做受 | 疯狂三人交性欧美 | 久久www免费人成人片 | 国产精品香蕉在线观看 | 欧美35页视频在线观看 | 在线播放免费人成毛片乱码 | 国产亚洲精品久久久久久大师 | 精品久久久中文字幕人妻 | 国产两女互慰高潮视频在线观看 | 无码吃奶揉捏奶头高潮视频 | 水蜜桃亚洲一二三四在线 | 福利一区二区三区视频在线观看 | 久久久精品国产sm最大网站 | 久久久精品人妻久久影视 | 色诱久久久久综合网ywww | 成人性做爰aaa片免费看不忠 | 久久久精品欧美一区二区免费 | 国产成人一区二区三区在线观看 | 妺妺窝人体色www婷婷 | 亚洲国产高清在线观看视频 | 一个人免费观看的www视频 | 18无码粉嫩小泬无套在线观看 | 国产精品久久久久久亚洲影视内衣 | 久久久无码中文字幕久... | 久久亚洲日韩精品一区二区三区 | 在线播放免费人成毛片乱码 | 麻花豆传媒剧国产免费mv在线 | 国产精品香蕉在线观看 | 亚洲精品www久久久 | 亚洲日韩av一区二区三区四区 | 欧美 日韩 人妻 高清 中文 | 日韩欧美群交p片內射中文 | 日韩亚洲欧美中文高清在线 | 国产亚洲精品精品国产亚洲综合 | 亚洲国产av美女网站 | 人妻有码中文字幕在线 | 成熟妇人a片免费看网站 | 欧美黑人巨大xxxxx | 兔费看少妇性l交大片免费 | 欧美freesex黑人又粗又大 | 国精品人妻无码一区二区三区蜜柚 | 少女韩国电视剧在线观看完整 | 波多野结衣aⅴ在线 | 欧美日韩亚洲国产精品 | 成年美女黄网站色大免费全看 | 好爽又高潮了毛片免费下载 | 成人欧美一区二区三区 | 精品国产一区av天美传媒 | 色窝窝无码一区二区三区色欲 | 丰满少妇弄高潮了www | 国产欧美亚洲精品a | 亚洲欧美日韩成人高清在线一区 | 国产香蕉97碰碰久久人人 | 国产精品久久国产精品99 | 娇妻被黑人粗大高潮白浆 | 狂野欧美性猛xxxx乱大交 | 国产av人人夜夜澡人人爽麻豆 | 日韩人妻无码中文字幕视频 | 亚洲成av人在线观看网址 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 国产69精品久久久久app下载 | 精品国产福利一区二区 | 99国产精品白浆在线观看免费 | 人妻中文无码久热丝袜 | 亚洲欧美日韩国产精品一区二区 | 最新国产麻豆aⅴ精品无码 | 九九在线中文字幕无码 | 国产精品久久久午夜夜伦鲁鲁 | 中文字幕无码乱人伦 | 亚洲日本一区二区三区在线 | 天堂亚洲2017在线观看 | 最近的中文字幕在线看视频 | 久久伊人色av天堂九九小黄鸭 | 亚洲日韩av一区二区三区四区 | 婷婷丁香五月天综合东京热 | a片在线免费观看 | 99精品久久毛片a片 | 国产成人午夜福利在线播放 | 麻豆成人精品国产免费 | 色窝窝无码一区二区三区色欲 | 麻豆蜜桃av蜜臀av色欲av | 亚洲无人区午夜福利码高清完整版 | 成人毛片一区二区 | 久久久久久亚洲精品a片成人 | 精品无码一区二区三区爱欲 | 四十如虎的丰满熟妇啪啪 | 中文无码成人免费视频在线观看 | 久久久精品国产sm最大网站 | 国产成人无码a区在线观看视频app | 国产午夜视频在线观看 | 日本大乳高潮视频在线观看 | 国产精品理论片在线观看 | 夜先锋av资源网站 | 天堂在线观看www | 亚洲国产av精品一区二区蜜芽 | 亚洲国产精品毛片av不卡在线 | 国产精品亚洲一区二区三区喷水 | 精品国产一区二区三区av 性色 | 丰满诱人的人妻3 | 日韩在线不卡免费视频一区 | 无码福利日韩神码福利片 | 欧美日本免费一区二区三区 | 人人妻人人澡人人爽人人精品 | 精品 日韩 国产 欧美 视频 | 国产成人午夜福利在线播放 | 国产香蕉尹人综合在线观看 | 欧美国产日产一区二区 | 俄罗斯老熟妇色xxxx | av在线亚洲欧洲日产一区二区 | 国产香蕉尹人综合在线观看 | 国产xxx69麻豆国语对白 | 日日麻批免费40分钟无码 | 18精品久久久无码午夜福利 | 狠狠躁日日躁夜夜躁2020 | 亚洲精品综合五月久久小说 | 久久97精品久久久久久久不卡 | 超碰97人人做人人爱少妇 | 国产成人综合在线女婷五月99播放 | av人摸人人人澡人人超碰下载 | 最新版天堂资源中文官网 | 99久久婷婷国产综合精品青草免费 | 色欲久久久天天天综合网精品 | 欧美怡红院免费全部视频 | 大地资源网第二页免费观看 | 久久午夜无码鲁丝片 | 国产明星裸体无码xxxx视频 | 四虎永久在线精品免费网址 | 永久黄网站色视频免费直播 | 欧美freesex黑人又粗又大 | 亚洲精品一区国产 | 真人与拘做受免费视频一 | 国产99久久精品一区二区 | 国产疯狂伦交大片 | 性欧美大战久久久久久久 | 色婷婷香蕉在线一区二区 | 无人区乱码一区二区三区 | 国产人妻大战黑人第1集 | 色婷婷综合激情综在线播放 | 欧美熟妇另类久久久久久不卡 | 国产在线精品一区二区三区直播 | 亚洲中文字幕无码一久久区 | 中文字幕中文有码在线 | 99久久99久久免费精品蜜桃 | 日日碰狠狠丁香久燥 | 亚洲一区二区三区无码久久 | 一本久久a久久精品亚洲 | 欧洲美熟女乱又伦 | 精品国偷自产在线视频 | 亚洲一区av无码专区在线观看 | 300部国产真实乱 | 日本高清一区免费中文视频 | 国产无av码在线观看 | 久久综合网欧美色妞网 | 男人和女人高潮免费网站 | 国产成人无码午夜视频在线观看 | 亚洲成av人在线观看网址 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国産精品久久久久久久 | 国产电影无码午夜在线播放 | 性欧美疯狂xxxxbbbb | 久久国产精品偷任你爽任你 | 97夜夜澡人人双人人人喊 | 亚洲日韩精品欧美一区二区 | 免费乱码人妻系列无码专区 | 久热国产vs视频在线观看 | 日本一区二区更新不卡 | 色五月丁香五月综合五月 | 中文字幕日产无线码一区 | 最近中文2019字幕第二页 | 亚洲日韩精品欧美一区二区 | 欧美日韩一区二区综合 | 亚洲精品无码国产 | 日本大香伊一区二区三区 | 国产成人精品久久亚洲高清不卡 | 国产成人无码av片在线观看不卡 | 日韩av激情在线观看 | 国产手机在线αⅴ片无码观看 | 麻花豆传媒剧国产免费mv在线 | 中文字幕人妻无码一区二区三区 | 国产亚洲精品久久久久久国模美 | 国产成人av免费观看 | 亚洲男女内射在线播放 | 蜜臀av在线播放 久久综合激激的五月天 | 曰韩少妇内射免费播放 | 午夜免费福利小电影 | а√天堂www在线天堂小说 | 四虎国产精品免费久久 | 色综合久久久久综合一本到桃花网 | 人妻无码αv中文字幕久久琪琪布 | 国产成人无码一二三区视频 | 亚洲高清偷拍一区二区三区 | a在线观看免费网站大全 | 婷婷综合久久中文字幕蜜桃三电影 | 久久亚洲中文字幕无码 | 精品亚洲成av人在线观看 | 国产人妻人伦精品1国产丝袜 | 少妇性l交大片 | 无码吃奶揉捏奶头高潮视频 | 亚洲欧美国产精品久久 | 国产av人人夜夜澡人人爽麻豆 | 熟妇女人妻丰满少妇中文字幕 | 国产在线精品一区二区高清不卡 | 丰满少妇高潮惨叫视频 | 国产麻豆精品一区二区三区v视界 | 久久99精品国产麻豆 | 2020最新国产自产精品 | 在线 国产 欧美 亚洲 天堂 | 激情爆乳一区二区三区 | 日产国产精品亚洲系列 | 久久久久久久久蜜桃 | 小泽玛莉亚一区二区视频在线 | 国产综合在线观看 | 两性色午夜免费视频 | 欧美丰满熟妇xxxx性ppx人交 | 日本一区二区三区免费高清 | 国产精品久免费的黄网站 | 精品日本一区二区三区在线观看 | 亚洲另类伦春色综合小说 | 国产亚洲精品久久久ai换 | 欧美亚洲日韩国产人成在线播放 | 国产小呦泬泬99精品 | 亚洲午夜无码久久 | 成人av无码一区二区三区 | 无人区乱码一区二区三区 | 国产区女主播在线观看 | 中文字幕av伊人av无码av | 成人无码视频在线观看网站 | 日韩在线不卡免费视频一区 | 少妇性荡欲午夜性开放视频剧场 | 成人性做爰aaa片免费看不忠 | 日日天日日夜日日摸 | 亚洲熟妇色xxxxx欧美老妇 | 日本一区二区三区免费高清 | 欧美性色19p | 成人aaa片一区国产精品 | 日本乱人伦片中文三区 | 黑人粗大猛烈进出高潮视频 | 少妇厨房愉情理9仑片视频 | 少妇太爽了在线观看 | 亚洲精品久久久久久一区二区 | 无码帝国www无码专区色综合 | 熟女俱乐部五十路六十路av | 性生交片免费无码看人 | 秋霞特色aa大片 | 图片区 小说区 区 亚洲五月 | 亚洲小说图区综合在线 | 日本一卡2卡3卡四卡精品网站 | 大地资源中文第3页 | 久9re热视频这里只有精品 | √天堂资源地址中文在线 | 精品水蜜桃久久久久久久 | 国产乱人偷精品人妻a片 | 亚洲一区av无码专区在线观看 | 又大又紧又粉嫩18p少妇 | 亚洲日韩乱码中文无码蜜桃臀网站 | 久久综合给合久久狠狠狠97色 | 偷窥日本少妇撒尿chinese | 99精品视频在线观看免费 | 人妻无码αv中文字幕久久琪琪布 | 国产激情精品一区二区三区 | 天堂а√在线地址中文在线 | 亚洲色欲色欲天天天www | 乱人伦人妻中文字幕无码久久网 | 国产成人无码一二三区视频 | 国产精品二区一区二区aⅴ污介绍 | 久久综合九色综合97网 | 国内精品九九久久久精品 | 伊人久久大香线蕉午夜 | 亚洲乱码日产精品bd | 日韩无码专区 | 国产极品美女高潮无套在线观看 | 欧美激情一区二区三区成人 | 日本护士xxxxhd少妇 | 亚洲国产精品一区二区第一页 | 好爽又高潮了毛片免费下载 | 亚洲精品国产品国语在线观看 | 熟女少妇人妻中文字幕 | 成人免费视频一区二区 | 亚洲色欲色欲欲www在线 | 国内精品一区二区三区不卡 | 久久精品人人做人人综合试看 | 免费无码午夜福利片69 | 色一情一乱一伦一视频免费看 | 欧美老妇交乱视频在线观看 | 人妻无码久久精品人妻 | 久久亚洲日韩精品一区二区三区 | 久久99精品久久久久久 | 无码人妻丰满熟妇区五十路百度 | 97久久精品无码一区二区 | 最新国产乱人伦偷精品免费网站 | 人人妻人人澡人人爽欧美一区九九 | 久久久久成人精品免费播放动漫 | 一二三四在线观看免费视频 | 少妇无码av无码专区在线观看 | 欧美 日韩 亚洲 在线 | 亚洲精品一区二区三区婷婷月 | 色综合久久中文娱乐网 | 中文字幕乱码亚洲无线三区 | 国产 浪潮av性色四虎 | 一本久道久久综合婷婷五月 | 大地资源网第二页免费观看 | 国产区女主播在线观看 | 国产精品亚洲综合色区韩国 | 国产精品久久福利网站 | 精品久久久久香蕉网 | 亚洲性无码av中文字幕 | 国产成人精品无码播放 | 亚洲色欲色欲天天天www | 又粗又大又硬又长又爽 | 成熟女人特级毛片www免费 | 欧美xxxx黑人又粗又长 | 亚洲综合无码一区二区三区 | 狠狠色噜噜狠狠狠7777奇米 | 在线播放免费人成毛片乱码 | 国产美女极度色诱视频www | 日日天干夜夜狠狠爱 | 久久国产精品_国产精品 | 亚洲gv猛男gv无码男同 | 色五月五月丁香亚洲综合网 | 99久久人妻精品免费二区 | 波多野结衣aⅴ在线 | 天天拍夜夜添久久精品大 | 一个人免费观看的www视频 | 亚洲精品午夜无码电影网 | 国内精品人妻无码久久久影院 | 一个人免费观看的www视频 | 性生交片免费无码看人 | 日本肉体xxxx裸交 | 色婷婷久久一区二区三区麻豆 | 国产偷国产偷精品高清尤物 | 精品一区二区三区无码免费视频 | 久久精品中文字幕大胸 | 久久精品视频在线看15 | 内射巨臀欧美在线视频 | 国产精品亚洲专区无码不卡 | 无码人妻精品一区二区三区不卡 | 国产黑色丝袜在线播放 | 熟妇激情内射com | 岛国片人妻三上悠亚 | 亚洲乱亚洲乱妇50p | 精品国产乱码久久久久乱码 | 国产真实夫妇视频 | 欧美喷潮久久久xxxxx | 午夜丰满少妇性开放视频 | 日日麻批免费40分钟无码 | 4hu四虎永久在线观看 | 国精产品一区二区三区 | 久久97精品久久久久久久不卡 | 狠狠综合久久久久综合网 | 国产精品久免费的黄网站 | 精品偷拍一区二区三区在线看 | 曰韩少妇内射免费播放 | 日韩视频 中文字幕 视频一区 | 久久久久se色偷偷亚洲精品av | 一本精品99久久精品77 | 亚洲自偷自偷在线制服 | 中国女人内谢69xxxxxa片 | 久久综合给久久狠狠97色 | 成人精品天堂一区二区三区 | 日日摸夜夜摸狠狠摸婷婷 | 日本免费一区二区三区最新 | 97色伦图片97综合影院 | 国产欧美精品一区二区三区 | 一本久久a久久精品vr综合 | 无码精品人妻一区二区三区av | 久久国产自偷自偷免费一区调 | 网友自拍区视频精品 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产亚洲美女精品久久久2020 | 特黄特色大片免费播放器图片 | 中文字幕无码免费久久9一区9 | 亚洲人成影院在线观看 | 国产av一区二区三区最新精品 | 亚洲日韩一区二区 | 国产av一区二区精品久久凹凸 | 帮老师解开蕾丝奶罩吸乳网站 | 日本一区二区三区免费高清 | √天堂中文官网8在线 | 中文精品久久久久人妻不卡 | 天天躁夜夜躁狠狠是什么心态 | 欧美午夜特黄aaaaaa片 | 欧美性猛交xxxx富婆 | 任你躁国产自任一区二区三区 | 特级做a爰片毛片免费69 | 亚洲欧洲日本无在线码 | 精品国产乱码久久久久乱码 | 国产色xx群视频射精 | 无码人妻黑人中文字幕 | 日韩亚洲欧美精品综合 | 少妇高潮一区二区三区99 | 日韩人妻无码一区二区三区久久99 | 黑人粗大猛烈进出高潮视频 | 无码人妻精品一区二区三区下载 | 中文无码成人免费视频在线观看 | 无遮挡国产高潮视频免费观看 | 国产精品久久久久无码av色戒 | 久精品国产欧美亚洲色aⅴ大片 | 中文无码成人免费视频在线观看 | 7777奇米四色成人眼影 | 亚洲国产av精品一区二区蜜芽 | 精品一二三区久久aaa片 | 奇米影视888欧美在线观看 | 巨爆乳无码视频在线观看 | 亚洲一区二区三区偷拍女厕 | 在线a亚洲视频播放在线观看 | 精品少妇爆乳无码av无码专区 | 亚洲狠狠婷婷综合久久 | 午夜性刺激在线视频免费 | 久久久精品国产sm最大网站 | 精品国产一区二区三区av 性色 | 无遮挡国产高潮视频免费观看 | 国产精品va在线观看无码 | 国产成人无码a区在线观看视频app | 亚洲 欧美 激情 小说 另类 | 97夜夜澡人人爽人人喊中国片 | 日本精品久久久久中文字幕 | 天天拍夜夜添久久精品 | 亚洲天堂2017无码 | 成人女人看片免费视频放人 | 性欧美牲交在线视频 | 老熟女重囗味hdxx69 | 99视频精品全部免费免费观看 | 国产乱码精品一品二品 | 老熟妇乱子伦牲交视频 | 成人免费无码大片a毛片 | 久久国产精品_国产精品 | 激情国产av做激情国产爱 | 精品人妻人人做人人爽夜夜爽 | 亚洲一区二区三区在线观看网站 | 国产亚洲精品久久久久久国模美 | 草草网站影院白丝内射 | 美女毛片一区二区三区四区 | 好男人社区资源 | 98国产精品综合一区二区三区 | 久久综合久久自在自线精品自 | 欧美国产日韩亚洲中文 | 久久成人a毛片免费观看网站 | 国产精品办公室沙发 | 18禁黄网站男男禁片免费观看 | 成在人线av无码免观看麻豆 | 亚洲日本在线电影 | 久久午夜夜伦鲁鲁片无码免费 | 又大又黄又粗又爽的免费视频 | 激情内射亚州一区二区三区爱妻 | 97se亚洲精品一区 | 精品aⅴ一区二区三区 | 九九在线中文字幕无码 | 亚洲va中文字幕无码久久不卡 | 性欧美熟妇videofreesex | 性色欲网站人妻丰满中文久久不卡 | 精品国偷自产在线视频 | 中文字幕av日韩精品一区二区 | 天天做天天爱天天爽综合网 | 中文字幕乱妇无码av在线 | 国产精品福利视频导航 | 色综合久久久久综合一本到桃花网 | 免费播放一区二区三区 | 三上悠亚人妻中文字幕在线 | 国产精品久久久久久亚洲毛片 | 精品偷自拍另类在线观看 | 欧美成人家庭影院 | 免费中文字幕日韩欧美 | 无码人妻精品一区二区三区不卡 | 精品熟女少妇av免费观看 | 中文字幕久久久久人妻 | 天天躁日日躁狠狠躁免费麻豆 | 国产精品多人p群无码 | 色情久久久av熟女人妻网站 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 理论片87福利理论电影 | 欧美性猛交xxxx富婆 | 久久人人97超碰a片精品 | 久久无码人妻影院 | 亚洲成av人影院在线观看 | 蜜桃视频插满18在线观看 | 国产网红无码精品视频 | 粉嫩少妇内射浓精videos | 日本高清一区免费中文视频 | 中文字幕av日韩精品一区二区 | 无码精品国产va在线观看dvd | 国产精品.xx视频.xxtv | 2020久久香蕉国产线看观看 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 国产精品无码永久免费888 | 日本精品久久久久中文字幕 | 国产熟女一区二区三区四区五区 | 一本大道伊人av久久综合 | 国产av无码专区亚洲awww | 亚洲国产精品久久人人爱 | 一区二区传媒有限公司 | 国产激情综合五月久久 | 久久久av男人的天堂 | 久久国产精品偷任你爽任你 | 欧美日韩一区二区综合 | 纯爱无遮挡h肉动漫在线播放 | 国产av剧情md精品麻豆 | 无码av岛国片在线播放 | 中文字幕乱码中文乱码51精品 | 永久免费观看美女裸体的网站 | 丰满少妇高潮惨叫视频 |