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

Vue 3.0 進階之應用創建的過程

開發 前端
在這篇文章中,阿寶哥將帶大家一起探索 Vue 3 中應用創建的過程。接下來,我們將從一個簡單的例子出發,從頭開始一步步分析 Vue 3.0 應用創建的過程。

[[385333]]

本文轉載自微信公眾號「全棧修仙之路」,作者阿寶哥。轉載本文請聯系全棧修仙之路公眾號。

本文是 Vue 3.0 進階系列 的第七篇文章,在這篇文章中,阿寶哥將帶大家一起探索 Vue 3 中應用創建的過程。接下來,我們將從一個簡單的例子出發,從頭開始一步步分析 Vue 3.0 應用創建的過程。

  1. <div id="app"></div> 
  2. <script> 
  3.    const { createApp, h } = Vue 
  4.    const app = createApp({ // ① 
  5.      data() { 
  6.        return { 
  7.          name'我是阿寶哥' 
  8.        } 
  9.      }, 
  10.      template: `<div>大家好, {{name}}!</div>` 
  11.    }) 
  12.    app.mount('#app') // ② 
  13. </script> 

 

 

 

在以上代碼中,首先我們通過 createApp 函數創建 app 對象,然后調用 app.mount 方法執行應用掛載操作。當以上代碼成功運行后,頁面上會顯示 大家好,我是阿寶哥!,具體如下圖所示:

 

對于以上的示例來說,它主要包含兩個步驟:創建 app 對象和應用掛載。這里我們只分析創建 app 對象的過程,而應用掛載的過程將在下一篇文章中介紹。

一、創建 app 對象

首先,阿寶哥利用 Chrome 開發者工具的 Performance 標簽欄,記錄了創建 app 對象的主要過程:

 

從圖中我們看到了在創建 app 對象過程中,所涉及的相關函數。為了讓大家能直觀地了解 app 對象創建的過程,阿寶哥畫了一張圖:

 

大致了解了主要過程之后,我們從 createApp 這個入口開始分析。接下來,打開 Chrome 開發者工具,在 createApp 處加個斷點:

 

通過斷點,我們找到了 createApp 函數,調用該函數之后會返回一個提供應用上下文的應用實例。應用實例掛載的整個組件樹共享同一個上下文。createApp 函數被定義在 runtime-dom/src/index.ts 文件中:

 

  1. // packages/runtime-dom/src/index.ts 
  2. export const createApp = ((...args) => { 
  3.   const app = ensureRenderer().createApp(...args) 
  4.  
  5.   const { mount } = app 
  6.   app.mount = (containerOrSelector: Element | ShadowRoot | string): any => { 
  7.     // 省略mount內部的處理邏輯 
  8.   } 
  9.   return app 
  10. }) as CreateAppFunction<Element> 

在 createApp 內部,會先調用 ensureRenderer 函數,該函數的內部代碼很簡單:

  1. // packages/runtime-dom/src/index.ts 
  2. function ensureRenderer() { 
  3.   return renderer || (renderer = createRenderer<Node, Element>(rendererOptions)) 

在以上代碼中會延遲創建渲染器,那么為什么要這樣做呢?我們從 runtime-dom/src/index.ts 文件中的注釋,找到了答案:

  1. // lazy create the renderer - this makes core renderer logic tree-shakable 
  2. // in case the user only imports reactivity utilities from Vue. 

對于我們的示例來說,是需要使用到渲染器的,所以會調用 createRenderer 函數創建渲染器。在分析 createRenderer 函數前,我們先來分析一下它的參數rendererOptions:

  1. // packages/runtime-dom/src/index.ts 
  2. export const extend = Object.assign 
  3. const rendererOptions = extend({ patchProp, forcePatchProp }, nodeOps) 

由以上代碼可知,參數 rendererOptions 是一個包含 patchProp、forcePatchProp 等屬性的對象,其中 nodeOps 是 node operations 的縮寫。對于 Web 瀏覽器環境來說,它定義了操作節點/元素的 API,比如創建元素、創建文本節點、插入元素和刪除元素等。因為 Vue 3.0 的源碼是使用 TypeScript 編寫的,所以可以在源碼中找到rendererOptions 參數的類型定義:

  1. // packages/runtime-core/src/renderer.ts 
  2. export interface RendererOptions< 
  3.   HostNode = RendererNode, 
  4.   HostElement = RendererElement 
  5. > { 
  6.   patchProp(el: HostElement, key: string, prevValue: any, nextValue: any, ...): void 
  7.   forcePatchProp?(el: HostElement, key: string): boolean 
  8.   insert(el: HostNode, parent: HostElement, anchor?: HostNode | null): void 
  9.   remove(el: HostNode): void 
  10.   createElement( type: string, isSVG?: boolean, isCustomizedBuiltIn?: string): HostElement 
  11.   createText(text: string): HostNode 
  12.   createComment(text: string): HostNode 
  13.   setText(node: HostNode, text: string): void 
  14.   setElementText(node: HostElement, text: string): void 
  15.   parentNode(node: HostNode): HostElement | null 
  16.   nextSibling(node: HostNode): HostNode | null 
  17.   querySelector?(selector: string): HostElement | null 
  18.   setScopeId?(el: HostElement, id: string): void 
  19.   cloneNode?(node: HostNode): HostNode 
  20.   insertStaticContent?(content: string, parent: HostElement, ...): HostElement[] 

在 RendererOptions 接口中定義了與渲染器相關的所有方法,這樣做的目的是對渲染器做了一層抽象。開發者在滿足該接口約束的情況下,就可以根據自己的需求實現自定義渲染器。了解完 rendererOptions 參數,我們來介紹 createRenderer 函數:

  1. // packages/runtime-core/src/renderer.ts 
  2. export interface RendererNode { 
  3.   [key: string]: any  // 索引簽名 
  4. export interface RendererElement extends RendererNode {} 
  5.  
  6. export function createRenderer< 
  7.   HostNode = RendererNode, 
  8.   HostElement = RendererElement 
  9. >(options: RendererOptions<HostNode, HostElement>) { 
  10.   return baseCreateRenderer<HostNode, HostElement>(options) 

在 createRenderer 函數內部會繼續調用 baseCreateRenderer 函數來執行創建渲染器的邏輯,該函數內部的邏輯比較復雜,這里我們先來看一下調用該函數后的返回結果:

  1. // packages/runtime-core/src/renderer.ts 
  2. function baseCreateRenderer( 
  3.   options: RendererOptions, 
  4.   createHydrationFns?: typeof createHydrationFunctions 
  5. ): any { 
  6.   // 省略大部分代碼 
  7.   return { 
  8.     render, 
  9.     hydrate, 
  10.     createApp: createAppAPI(render, hydrate) 
  11.   } 

在以上代碼中,我們終于看到了期待已久的 createApp 屬性,該屬性的值是調用 createAppAPI 函數后的返回結果。看過阿寶哥之前文章的小伙伴,對 createAppAPI 函數應該不會陌生,它被定義在 runtime-core/src/apiCreateApp.ts 文件中:

  1. // packages/runtime-core/src/apiCreateApp.ts 
  2. export function createAppAPI<HostElement>( 
  3.   render: RootRenderFunction, 
  4.   hydrate?: RootHydrateFunction 
  5. ): CreateAppFunction<HostElement> { 
  6.   return function createApp(rootComponent, rootProps = null) { 
  7.     const context = createAppContext() 
  8.     const installedPlugins = new Set() 
  9.     let isMounted = false 
  10.     const app: App = (context.app = { 
  11.       _uid: uid++, 
  12.       _component: rootComponent as ConcreteComponent, 
  13.       _context: context, 
  14.       // 省略use、mixin、unmount和provide等方法 
  15.       component(name: string, component?: Component): any { 
  16.      // ... 
  17.       }, 
  18.       directive(name: string, directive?: Directive) { 
  19.         // ... 
  20.       }, 
  21.       mount(rootContainer: HostElement, isHydrate?: boolean): any { 
  22.         // ... 
  23.       }, 
  24.     }) 
  25.     return app 
  26.   } 

通過以上的代碼可知,createApp 方法支持 rootComponent 和 rootProps 兩個參數,調用該方法之后會返回一個 app 對象,該對象為了開發者提供了多個應用 API,比如,用于注冊或檢索全局組件的 component 方法,用于注冊或檢索全局指令的 directive方法及用于將應用實例的根組件掛載到指定 DOM 元素上的 mount 方法等。

此外,在 createApp 函數體中,我們看到了 const context = createAppContext() 這行代碼。顧名思義,createAppContext 函數用于創建與當前應用相關的上下文對象。那么所謂的上下文對象長啥樣呢?要搞清楚這個問題,我們來看一下 createAppContext 函數的具體實現:

  1. // packages/runtime-core/src/apiCreateApp.ts 
  2. export function createAppContext(): AppContext { 
  3.   return { 
  4.     app: null as any
  5.     config: { ... }, 
  6.     mixins: [], 
  7.     components: {}, 
  8.     directives: {}, 
  9.     provides: Object.create(null
  10.   } 

介紹完 app 和 context 對象之后,我們來繼續分析 createApp 函數剩下的邏輯代碼:

 

  1. // packages/runtime-dom/src/index.ts 
  2. export const createApp = ((...args) => { 
  3.   const app = ensureRenderer().createApp(...args) 
  4.  
  5.   const { mount } = app 
  6.   app.mount = (containerOrSelector: Element | ShadowRoot | string): any => { 
  7.     // 省略mount內部的處理邏輯 
  8.   } 
  9.   return app 
  10. }) as CreateAppFunction<Element> 

由以上代碼可知,在創建完 app 對象之后,并不會立即返回已創建的 app 對象,而是會重寫 app.mount 屬性:

 

  1. // packages/runtime-dom/src/index.ts 
  2. export const createApp = ((...args) => { 
  3.   const app = ensureRenderer().createApp(...args) 
  4.  
  5.   const { mount } = app 
  6.   app.mount = (containerOrSelector: Element | ShadowRoot | string): any => { 
  7.     const container = normalizeContainer(containerOrSelector) // 同時支持字符串和DOM對象 
  8.     if (!container) return 
  9.     const component = app._component 
  10.     // 若根組件非函數對象且未設置render和template屬性,則使用容器的innerHTML作為模板的內容 
  11.     if (!isFunction(component) && !component.render && !component.template) { 
  12.       component.template = container.innerHTML 
  13.     } 
  14.     container.innerHTML = '' // 在掛載前清空容器內容 
  15.     const proxy = mount(container) // 執行掛載操作 
  16.     if (container instanceof Element) { 
  17.       container.removeAttribute('v-cloak') // 避免在網絡不好或加載數據過大的情況下,頁面渲染的過程中會出現Mustache標簽 
  18.       container.setAttribute('data-v-app'''
  19.     } 
  20.     return proxy 
  21.   } 
  22.  
  23.   return app 
  24. }) as CreateAppFunction<Element> 

在 app.mount 方法內部,當設置好根組件的相關信息之后,就會調用 app 對象原始的mount 方法執行掛載操作:

  1. // packages/runtime-core/src/apiCreateApp.ts 
  2. export function createAppAPI<HostElement>( 
  3.   render: RootRenderFunction, 
  4.   hydrate?: RootHydrateFunction 
  5. ): CreateAppFunction<HostElement> { 
  6.   return function createApp(rootComponent, rootProps = null) { 
  7.     const context = createAppContext() 
  8.     const installedPlugins = new Set() 
  9.  
  10.     let isMounted = false // 標識是否已掛載 
  11.  
  12.     const app: App = (context.app = { 
  13.       _uid: uid++, 
  14.       _component: rootComponent as ConcreteComponent, 
  15.       _props: rootProps, 
  16.       _context: context, 
  17.  
  18.       mount(rootContainer: HostElement, isHydrate?: boolean): any { 
  19.         if (!isMounted) { 
  20.           // 基于根組件和根組件屬性創建對應的VNode節點 
  21.           const vnode = createVNode( 
  22.             rootComponent as ConcreteComponent, 
  23.             rootProps 
  24.           ) 
  25.           vnode.appContext = context // 應用上下文 
  26.           if (isHydrate && hydrate) { // 與服務端渲染相關 
  27.             hydrate(vnode as VNode<Node, Element>, rootContainer as any
  28.           } else { // 把vnode渲染到根容器中 
  29.             render(vnode, rootContainer) 
  30.           } 
  31.           isMounted = true // 設置已掛載的狀態  
  32.           app._container = rootContainer 
  33.           return vnode.component!.proxy 
  34.         } 
  35.       }, 
  36.     }) 
  37.  
  38.     return app 
  39.   } 

那么為什么要重寫 app.mount 方法呢?原因是為了支持跨平臺,在 runtime-dom 包中定義的 app.mount 方法,都是與 Web 平臺有關的方法。另外,在 runtime-dom 包中,還會為 Web 平臺創建該平臺對應的渲染器。即在創建渲染器時,使用的 nodeOps 對象中封裝了 DOM 相關的 API:

  1. // packages/runtime-dom/src/nodeOps.ts 
  2. export const nodeOps: Omit<RendererOptions<Node, Element>, 'patchProp'> = { 
  3.   // 省略部分方法 
  4.   createElement: (tag, isSVG, is): Element => 
  5.     isSVG ? doc.createElementNS(svgNS, tag) : doc.createElement(tag, is ? { is } : undefined), 
  6.   createText: text => doc.createTextNode(text), 
  7.   createComment: text => doc.createComment(text), 
  8.   querySelector: selector => doc.querySelector(selector), 

現在創建 app 對象的過程中涉及的主要函數已經介紹完了,對這個過程還不理解的小伙伴,可以參考阿寶哥前面畫的圖,然后斷點調試一下創建 app 對象的過程。

 

二、阿寶哥有話說

2.1 App 對象提供哪些 API?

在 Vue 3 中,改變全局 Vue 行為的 API 現在被移動到了由新的 createApp 方法所創建的應用實例上。應用實例為我們提供了以下 API 來實現特定的功能:

  • config():包含應用配置的對象。
  • unmount():在提供的 DOM 元素上卸載應用實例的根組件。
  • mixin(mixin: ComponentOptions):將一個 mixin 應用在整個應用范圍內。
  • provide(key, value):設置一個可以被注入到應用范圍內所有組件中的值。
  • component(name: string, component?: Component):注冊或檢索全局組件。
  • directive(name: string, directive?: Directive):注冊或檢索全局指令。
  • use(plugin: Plugin, ...options: any[]):安裝 Vue.js 插件,當在同一個插件上多次調用此方法時,該插件將僅安裝一次。
  • mount(rootContainer: HostElement, isHydrate?: boolean,isSVG?: boolean):將應用實例的根組件掛載在提供的 DOM 元素上。

2.2 使用 createApp 函數可以創建多個 Vue 應用么?

通過 createApp 函數,我們可以輕松地創建多個 Vue 應用。每個應用的上下文環境都是互相隔離的,具體的使用方式如下所示:

  1. <div id="appA"></div> 
  2. <hr> 
  3. <div id="appB"></div> 
  4. <script> 
  5.   const { createApp, h } = Vue 
  6.   const appA = createApp({ 
  7.     template: "我是應用A" 
  8.   }) 
  9.   const appB = createApp({ 
  10.     template: "我是應用B" 
  11.   }) 
  12.   appA.mount('#appA')  
  13.   appB.mount('#appB')  
  14. </script> 

本文主要介紹了在 Vue 3 中創建 App 對象的主要過程及 App 對象上相關的 API。為了讓大家能夠更深入地理解 App 對象創建的過程,阿寶哥還從源碼的角度分析了該過程中涉及的主要函數。在下一篇文章中,阿寶哥將會介紹應用掛載的過程,感興趣的小伙伴不要錯過喲。

三、參考資源

 

Vue 3 官網 - 全局 API

 

責任編輯:武曉燕 來源: 全棧修仙之路
相關推薦

2021-03-08 00:08:29

Vue應用掛載

2021-02-16 16:41:45

Vue項目指令

2021-02-26 05:19:20

Vue 3.0 VNode虛擬

2021-02-28 20:41:18

Vue注入Angular

2021-02-19 23:07:02

Vue綁定組件

2021-02-22 21:49:33

Vue動態組件

2021-02-18 08:19:21

Vue自定義Vue 3.0

2021-03-09 22:29:46

Vue 響應式API

2011-07-19 15:18:46

存儲過程sql語句

2020-10-13 08:24:31

Vue3.0系列

2011-06-23 15:10:39

Qt 窗體

2021-04-26 18:48:48

微應用React

2010-04-23 11:15:43

Oracle創建

2017-02-27 11:48:58

JVM源碼分析Java

2009-10-22 14:05:55

CLR存儲過程

2020-11-02 11:33:52

ReactVue應用

2020-04-22 14:15:32

Vue 3.0語法前端

2011-08-17 16:16:29

iPhone應用程序啟動過程

2024-01-03 15:31:16

網格布局ArkTSGrid

2018-11-05 15:14:42

MySQL編程語言技術
點贊
收藏

51CTO技術棧公眾號

伊人久久大香线蕉综合网蜜芽| 性欧美高清come| 免费精品视频最新在线| 久久人体大胆视频| 日本一级大毛片a一| 日韩伦理在线一区| 国产精品青草久久| 国产欧美日韩一区| 亚洲一区二区人妻| 亚洲国产午夜| 久久久久www| 亚洲国产欧美视频| 视频一区国产| 欧美日韩专区在线| 日韩网址在线观看| 伊人福利在线| 欧美激情一区不卡| 精品国产免费人成电影在线观...| 瑟瑟视频在线免费观看| 日韩午夜激情| 欧美精品亚州精品| 黄色国产在线播放| 亚洲ab电影| 精品日本一线二线三线不卡| 亚洲免费看av| 中文字幕乱码在线播放| 亚洲一区二区三区四区在线免费观看 | 中文字幕一区日韩精品| 欧美视频一区二区三区在线观看 | 在线日韩国产网站| 亚州精品视频| 亚洲成人av片| 老女人性生活视频| 祥仔av免费一区二区三区四区| 精品毛片三在线观看| avav在线播放| 免费在线中文字幕| 亚洲精品免费一二三区| 亚洲欧洲另类精品久久综合| 色猫av在线| 国产91丝袜在线18| 波多野结衣久草一区| 国产精品久久免费| 久久电影国产免费久久电影| 国产精品久久久久久久久久久久久久 | 日韩美一区二区三区| 一级做a免费视频| 久久av影院| 欧美日韩大陆一区二区| 国产aaaaa毛片| 日韩和的一区二在线| 一本一道综合狠狠老| 国产免费一区二区三区视频| 色戒汤唯在线观看| 欧美午夜丰满在线18影院| 男人添女人下面高潮视频| 99thz桃花论族在线播放| 午夜精品aaa| 色综合久久久久无码专区| аⅴ资源天堂资源库在线| 精品久久久久久久久久国产| 精品国产一区三区| 欧美gay囗交囗交| 在线观看一区二区视频| 亚洲天堂2018av| 亚洲综合伊人| 日韩欧美一区二区在线视频| 国内精品免费视频| 欧洲亚洲视频| 这里只有精品久久| 丁香花五月激情| 影音先锋久久精品| 欧美在线视频一区二区| 日本一区二区三区久久| 国产最新精品免费| 国产精品免费一区二区三区在线观看 | 国产一区福利在线| 国产伦精品一区二区三区照片91| 亚洲欧美丝袜中文综合| 国产欧美一区二区三区鸳鸯浴| 亚洲欧洲精品在线| 美女日批视频在线观看| 色天天综合久久久久综合片| 国产免费又粗又猛又爽| 伊人精品综合| 亚洲一区二区精品| 中文字幕在线观看成人| 美女精品在线观看| 亚洲曰本av电影| 五月婷婷伊人网| 成人免费一区二区三区在线观看| 天堂8在线天堂资源bt| 欧美人体一区二区三区| 欧美一区二区在线视频| 日韩网站在线播放| 亚洲91中文字幕无线码三区| 97在线视频精品| 在线中文字幕网站| www.色精品| 二级片在线观看| 亚洲精品永久免费视频| 日韩午夜激情视频| 中字幕一区二区三区乱码| 精品91在线| 国产区精品视频| 国产精品国产高清国产| 亚洲欧美另类久久久精品2019| 免费毛片小视频| 日韩精品一级| 在线亚洲国产精品网| 黄色片视频网站| 极品美女销魂一区二区三区 | 国产一区久久| 日本中文字幕成人| 男人天堂av网| 亚洲日本青草视频在线怡红院 | 亚洲人成免费电影| 精品午夜福利在线观看| 激情久久五月天| 秋霞毛片久久久久久久久| 国产经典三级在线| 56国语精品自产拍在线观看| 我和岳m愉情xxxⅹ视频| 在线欧美三区| 成人av免费看| 视频在线这里都是精品| 欧美精品在线观看一区二区| 鲁丝一区二区三区| 国产欧美成人| 国产欧美日韩综合一区在线观看 | 午夜精品影院在线观看| 国产黑丝在线视频| 99久久视频| 国产有码在线一区二区视频| 国产资源在线看| 欧美性感美女h网站在线观看免费| 欧美熟妇精品一区二区| 91精品啪在线观看国产18 | 一级全黄少妇性色生活片| 久久久久国产精品厨房| 国产成人久久777777| 欧美日韩一区二区三区四区不卡 | 国产亚洲精品成人av久久ww | 91精品国产手机| jizzjizz日本少妇| 久久精品国产99国产| 亚洲欧美日韩精品在线| 久久精品嫩草影院| 日韩有码在线观看| 国产精品无码免费播放| 亚洲男人的天堂一区二区| www.污网站| 欧美特黄视频| 精品欧美日韩在线| 中文字幕影音在线| 亚洲天堂开心观看| 一本到在线视频| 亚洲精品欧美专区| 亚洲婷婷在线观看| 国产日韩一区二区三区在线| 欧美日韩国产高清视频| 日韩天堂在线| 俺去亚洲欧洲欧美日韩| av免费在线观看不卡| 亚洲综合成人网| 9.1成人看片| 青青青伊人色综合久久| 在线天堂一区av电影| 日韩精品一区国产| 91精品国产91久久久久久久久| 青青青免费视频在线2| 欧美无人高清视频在线观看| 日韩av毛片在线观看| 国产成人a级片| 久久网站免费视频| 日韩精品诱惑一区?区三区| 成人av在线亚洲| 国产偷倩在线播放| 亚洲午夜女主播在线直播| 国产精品伦理一区| 午夜精品在线看| 99热99这里只有精品| 成人美女在线视频| 在线观看高清免费视频| 欧美va天堂在线| 欧美成人dvd在线视频| 四虎国产精品免费久久5151| 久久男人的天堂| 99reav在线| 精品福利一区二区三区免费视频| 中文字幕手机在线视频| 亚洲麻豆国产自偷在线| 自拍偷拍亚洲天堂| 国产黄色精品视频| 国产 porn| 最新成人av网站| 日韩最新中文字幕| 欧洲vs亚洲vs国产| 91香蕉亚洲精品| 搜成人激情视频| 久久免费视频网| а√天堂资源地址在线下载| 亚洲欧洲一区二区三区久久| 亚洲第一色网站| 欧美三级日韩在线| 天堂在线免费观看视频| 亚洲主播在线观看| 国精产品一区一区二区三区mba| 26uuu国产日韩综合| 亚洲AV无码久久精品国产一区| 丝袜美腿亚洲一区| 国产在线播放观看| 中文字幕一区二区三三| 亚洲人一区二区| 国产一区日韩| 久久精品99久久| 国产伦理久久久久久妇女| 成人免费观看网址| 成人h在线观看| 欧美孕妇孕交黑巨大网站| 免费不卡av| 久久99国产综合精品女同| 免费黄色网址在线观看| 在线视频欧美日韩| 麻豆国产在线播放| 亚洲欧美国产va在线影院| 色欲av永久无码精品无码蜜桃| 日韩一区二区免费在线观看| 亚洲字幕av一区二区三区四区| 一本大道av伊人久久综合| 日韩av一区二区在线播放| 亚洲国产美国国产综合一区二区| 亚洲一级生活片| 亚洲婷婷综合色高清在线| 国精产品视频一二二区| 国产喂奶挤奶一区二区三区| 亚洲av无码成人精品国产| 99久久久免费精品国产一区二区| 精人妻一区二区三区| 国产不卡视频在线播放| 91精产国品一二三| 国产精品18久久久久久久久久久久| 亚洲18在线看污www麻豆| 久久成人精品无人区| 日韩高清第一页| 黄页视频在线91| 亚洲av毛片在线观看| 国产精品影视天天线| 中国老熟女重囗味hdxx| 国产不卡在线一区| 中文字幕 亚洲一区| 91蜜桃传媒精品久久久一区二区| 美女久久久久久久久久| 国产欧美一区二区三区在线看蜜臀 | 性生活三级视频| 精品国精品国产| 日韩有码第一页| 日韩精品欧美国产精品忘忧草| 涩爱av在线播放一区二区| 亚洲欧洲激情在线| 麻豆传媒视频在线观看免费| 美女国内精品自产拍在线播放| 手机在线免费看av| 欧美综合激情网| 岛国一区二区| 国产传媒欧美日韩| 最新亚洲精品| 伊人狠狠色丁香综合尤物| 欧美激情第10页| 欧美性大战久久久久xxx| 免费久久精品视频| 人妻 丝袜美腿 中文字幕| 久久免费视频色| 91免费公开视频| 五月综合激情网| 99成人精品视频| 日韩一区二区三区三四区视频在线观看| 色综合久久久久久| 一区二区中文字幕| 午夜伦理在线视频| 日本精品视频网站| 国产精品va视频| 麻豆精品传媒视频| 久久久久国产精品| 国产免费黄色av| 韩国三级在线一区| 亚洲第九十七页| 日韩毛片一二三区| 全部毛片永久免费看| 7777精品伊人久久久大香线蕉的| 黑人乱码一区二区三区av| 亚洲日韩中文字幕| 日本成人不卡| 国产日韩av高清| 久久精品国产亚洲blacked| 亚洲五月六月| aa亚洲婷婷| 97免费公开视频| 国产欧美一区二区精品秋霞影院 | 成人av黄色| 欧美中文字幕在线播放| 日韩精品三级| 一级做a爰片久久| 国产一级一区二区| 少妇性l交大片7724com| 国产精品水嫩水嫩| 欧美日韩一二三四区| 日韩免费观看高清完整版| 在线观看a视频| 欧美专区在线播放| 7m精品国产导航在线| 一级日韩一区在线观看| 久久欧美肥婆一二区| 69xxx免费视频| 亚洲日本在线观看| 一女二男一黄一片| 夜夜嗨av色综合久久久综合网 | 午夜国产精品视频免费体验区| 国产黄色特级片| 91在线视频观看| 久久精品国产亚洲av麻豆色欲| 欧美精品高清视频| √天堂资源地址在线官网| 国产福利视频一区二区| 日韩欧美黄色| 香港三级韩国三级日本三级| 国产成人av在线影院| 日韩精品一区二区亚洲av性色| 欧美熟乱第一页| 国产成人天天5g影院在线观看| 456亚洲影院| 台湾色综合娱乐中文网| 日韩伦理在线免费观看| 成人福利视频网站| 九九热这里有精品视频| 日韩一二在线观看| 18在线观看的| 国产高清在线一区| 欧美成人中文| 丰满人妻一区二区三区53视频| 一区在线观看视频| 国产精品毛片久久久久久久av| 日韩视频免费观看| 精品国产一区二| 国产日产欧美一区二区| 国产成人午夜99999| 久久久精品91| 亚洲精品在线电影| 丝袜老师在线| 日本一区二区三区免费看| 日本少妇一区二区| 永久免费未视频| 欧美一区二区三区视频免费| 18视频在线观看网站| 国产日韩欧美一区二区| 国产日韩综合| 先锋影音av在线| 欧美久久久影院| 午夜羞羞小视频在线观看| 国产精品综合久久久久久| 亚洲视频1区| 久久视频一区二区三区| 91精品一区二区三区久久久久久| h片在线播放| 国模一区二区三区私拍视频| 欧美亚洲在线| 国产一区二区三区视频播放| 欧美一区午夜视频在线观看| 17videosex性欧美| 日韩欧美三级电影| 国产一区二区美女| 日韩成人免费观看| 中文字幕国产精品久久| 久久伊人影院| 各处沟厕大尺度偷拍女厕嘘嘘| 国产精品欧美综合在线| 亚洲av色香蕉一区二区三区| 91高清视频在线免费观看| 欧美亚洲激情| 不许穿内裤随时挨c调教h苏绵| 日韩欧美国产骚| 欧美精品hd| 精品人伦一区二区三区| 久久国产精品99精品国产 | 国产精品久久久久久久久久直播 | 亚洲综合不卡| 欧美一级片在线视频| 亚洲精品国产suv| 羞羞视频在线观看一区二区| 欧美 日韩 国产 高清| 综合欧美一区二区三区| 五月婷婷久久久| 91久久精品美女高潮| 国产精品人人爽人人做我的可爱| a级黄色免费视频| 亚洲欧美第一页| 国产精品tv| 午夜影院免费版| 在线观看亚洲专区| 免费h在线看|