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

最近很火的Vue Vine是如何實(shí)現(xiàn)一個(gè)文件中寫(xiě)多個(gè)組件

開(kāi)發(fā) 前端
Vue Vine是一個(gè)vite插件,vite解析每個(gè)模塊時(shí)都會(huì)觸發(fā)插件的transform?鉤子函數(shù)。在鉤子函數(shù)中會(huì)去判斷當(dāng)前文件是否以.vine.ts結(jié)尾的,如果不是則return。

前言

在今年的Vue Conf 2024大會(huì)上,沈青川大佬(維護(hù)Vue/Vite 中文文檔)在會(huì)上介紹了他的新項(xiàng)目Vue Vine。Vue Vine提供了全新Vue組件書(shū)寫(xiě)方式,主要的賣(mài)點(diǎn)是可以在一個(gè)文件里面寫(xiě)多個(gè)vue組件。相信你最近應(yīng)該看到了不少介紹Vue Vine的文章,這篇文章我們另辟蹊徑來(lái)講講Vue Vine是如何實(shí)現(xiàn)在一個(gè)文件里面寫(xiě)多個(gè)vue組件。

看個(gè)demo

我們先來(lái)看普通的vue組件,about.vue代碼如下:

<template>
  <h3>i am about page</h3>
</template>

<script lang="ts" setup></script>

我們?cè)跒g覽器中來(lái)看看編譯后的js代碼,代碼如下:

const _sfc_main = {};

function _sfc_render(_ctx, _cache) {
  return _openBlock(), _createElementBlock("h3", null, "i am about page");
}

_sfc_main.render = _sfc_render;
export default _sfc_main;

從上面的代碼可以看到普通的vue組件編譯后生成的js文件會(huì)export default導(dǎo)出一個(gè)_sfc_main組件對(duì)象,并且這個(gè)組件對(duì)象上面有個(gè)大名鼎鼎的render函數(shù)。父組件只需要import導(dǎo)入子組件里面export default導(dǎo)出的_sfc_main組件對(duì)象就可以啦。

搞清楚普通的vue組件編譯后是什么樣的,我們接著來(lái)看一個(gè)Vue Vine的demo,Vue Vine的組件必須以.vine.ts 結(jié)尾,home.vine.ts代碼如下:

async function ChildComp() {
  return vine`
    <h3>我是子組件</h3>
  `;
}

export async function Home() {
  return vine`
  <h3>我是父組件</h3>
    <ChildComp  />
  `;
}

如果你熟悉react,你會(huì)發(fā)現(xiàn)Vine 組件函數(shù)和react比較相似,不同的是return的時(shí)候需要在其返回值上顯式使用 vine 標(biāo)記的模板字符串。

在瀏覽器中來(lái)看看home.vine.ts編譯后的代碼,代碼如下:

export const ChildComp = (() => {
  const __vine = _defineComponent({
    name: "ChildComp",
    setup(__props, { expose: __expose }) {
      // ...省略
    },
  });

  function __sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
    return _openBlock(), _createElementBlock("h3", null, "我是子組件");
  }

  __vine.render = __sfc_render;
  return __vine;
})();

export const Home = (() => {
  const __vine = _defineComponent({
    name: "Home",
    setup(__props, { expose: __expose }) {
      // ...省略
    },
  });

  function __sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
    return (
      _openBlock(),
      _createElementBlock(
        _Fragment,
        null,
        [_hoisted_1, _createVNode($setup["ChildComp"])],
        64,
      )
    );
  }

  __vine.render = __sfc_render;
  return __vine;
})();

從上面的代碼可以看到組件ChildComp和Home編譯后是一個(gè)立即調(diào)用函數(shù),在函數(shù)中return了__vine組件對(duì)象,并且這個(gè)組件對(duì)象上面也有render函數(shù)。想必細(xì)心的你已經(jīng)發(fā)現(xiàn)了在同一個(gè)文件里面定義的多個(gè)組件經(jīng)過(guò)編譯后,從常規(guī)的export default導(dǎo)出一個(gè)默認(rèn)的vue組件對(duì)象變成了export導(dǎo)出多個(gè)具名的vue組件對(duì)象。

接下來(lái)我們將通過(guò)debug的方式帶你搞清楚Vue Vine是如何實(shí)現(xiàn)一個(gè)文件內(nèi)導(dǎo)出多個(gè)vue組件對(duì)象。

createVinePlugin函數(shù)

我們遇見(jiàn)的第一個(gè)問(wèn)題是需要找到從哪里開(kāi)始著手debug?

來(lái)看一下官方文檔是接入vue vine的,如下圖:

圖片圖片

從上圖中可以看到vine是一個(gè)vite插件,以插件的形式起作用的。

現(xiàn)在我們找到了一切起源就是這個(gè)VineVitePlugin函數(shù),所以我們需要給vite.config.ts文件中的VineVitePlugin函數(shù)打個(gè)斷點(diǎn)。如下圖:

圖片圖片

接下來(lái)我們需要啟動(dòng)一個(gè)debug終端。這里以vscode舉例,打開(kāi)終端然后點(diǎn)擊終端中的+號(hào)旁邊的下拉箭頭,在下拉中點(diǎn)擊Javascript Debug Terminal就可以啟動(dòng)一個(gè)debug終端。

圖片圖片

在debug終端執(zhí)行yarn dev,在瀏覽器中打開(kāi)對(duì)應(yīng)的頁(yè)面,比如:http://localhost:3333/ 。此時(shí)代碼將會(huì)停留在我們打的斷點(diǎn)VineVitePlugin函數(shù)調(diào)用處,讓代碼走進(jìn)VineVitePlugin函數(shù),發(fā)現(xiàn)這個(gè)函數(shù)實(shí)際定義的名字叫createVinePlugin,在我們這個(gè)場(chǎng)景中簡(jiǎn)化后的createVinePlugin函數(shù)代碼如下:

function createVinePlugin() {
  return {
    name: "vue-vine-plugin",
    async resolveId(id) {
      // ...省略
    },
    async load(id) {
      // ...省略
    },
    async transform(code, id) {
      const { fileId, query } = parseQuery(id);
      if (!fileId.endsWith(".vine.ts") || query.type === QUERY_TYPE_STYLE) {
        return;
      }
      return runCompileScript(code, id);
    },
    async handleHotUpdate(ctx) {
      // ...省略
    }
  };
}

從上面的代碼可以看到插件中有不少鉤子函數(shù),vite會(huì)在對(duì)應(yīng)的時(shí)候調(diào)用這些插件的鉤子函數(shù),比如當(dāng)vite解析每個(gè)模塊時(shí)就會(huì)調(diào)用transform等函數(shù)。

transform鉤子函數(shù)的接收的第一個(gè)參數(shù)為code,是當(dāng)前文件的code代碼字符串。第二個(gè)參數(shù)為id,是當(dāng)前文件路徑,這個(gè)路徑可能帶有query。

在transform鉤子函數(shù)中先調(diào)用parseQuery函數(shù)根據(jù)當(dāng)前文件路徑拿到去除query的文件路徑,以及query對(duì)象。

!fileId.endsWith(".vine.ts") 的意思是判斷當(dāng)前文件是不是.vine.ts結(jié)尾的文件,如果不是則不進(jìn)行任何處理,這也就是為什么文檔中會(huì)寫(xiě)Vue Vine只支持.vine.ts結(jié)尾的文件。

query.type === QUERY_TYPE_STYLE的意思是判斷當(dāng)前文件是不是css文件,因?yàn)橥粋€(gè)vue文件會(huì)被處理兩次,第一次處理時(shí)只會(huì)處理template和script這兩個(gè)模塊,第二次再去單獨(dú)處理style模塊。

在transform鉤子函數(shù)的最后就是調(diào)用runCompileScript(code, id)函數(shù),并且將其執(zhí)行結(jié)果進(jìn)行返回。

runCompileScript函數(shù)

接著將斷點(diǎn)走進(jìn)runCompileScript函數(shù),在我們這個(gè)場(chǎng)景中簡(jiǎn)化后的runCompileScript函數(shù)代碼如下:

const runCompileScript = (code, fileId) => {
  const vineFileCtx = compileVineTypeScriptFile(
    code,
    fileId,
    compilerHooks,
    fileCtxMap,
  );

  return {
    code: vineFileCtx.fileMagicCode.toString(),
  };
};

從上面的代碼可以看到首先會(huì)以code(當(dāng)前文件的code代碼字符串)為參數(shù)去執(zhí)行compileVineTypeScriptFile函數(shù),這個(gè)函數(shù)會(huì)返回一個(gè)vineFileCtx上下文對(duì)象。這個(gè)上下文對(duì)象的fileMagicCode.toString(),就是前面我們?cè)跒g覽器中看到的最終編譯好的js代碼。

compileVineTypeScriptFile函數(shù)

接著將斷點(diǎn)走進(jìn)compileVineTypeScriptFile函數(shù),在我們這個(gè)場(chǎng)景中簡(jiǎn)化后的compileVineTypeScriptFile函數(shù)代碼如下:

function compileVineTypeScriptFile(
  code: string,
  fileId: string,
  compilerHooks: VineCompilerHooks,
  fileCtxCache?: VineFileCtx,
) {
  const vineFileCtx: VineFileCtx = createVineFileCtx(
    code,
    fileId,
    fileCtxCache,
  );
  const vineCompFnDecls = findVineCompFnDecls(vineFileCtx.root);
  doAnalyzeVine(compilerHooks, vineFileCtx, vineCompFnDecls);
  transformFile(
    vineFileCtx,
    compilerHooks,
    compilerOptions?.inlineTemplate ?? true,
  );

  return vineFileCtx;
}

在執(zhí)行compileVineTypeScriptFile函數(shù)之前,我們?cè)赿ebug終端來(lái)看看接收的第一個(gè)參數(shù)code,如下圖:

圖片圖片

從上圖中可以看到第一個(gè)參數(shù)code就是我們寫(xiě)的home.vine.ts文件中的源代碼。

createVineFileCtx函數(shù)

接下來(lái)看第一個(gè)函數(shù)調(diào)用createVineFileCtx,這個(gè)函數(shù)返回一個(gè)vineFileCtx上下文對(duì)象。將斷點(diǎn)走進(jìn)createVineFileCtx函數(shù),在我們這個(gè)場(chǎng)景中簡(jiǎn)化后的createVineFileCtx函數(shù)代碼如下:

import MagicString from 'magic-string'

function createVineFileCtx(code: string, fileId: string) {
  const root = babelParse(code);
  const vineFileCtx: VineFileCtx = {
    root,
    fileMagicCode: new MagicString(code),
    vineCompFns: [],
    // ...省略
  };
  return vineFileCtx;
}

由于Vue Vine中的組件和react相似是組件函數(shù),組件函數(shù)中當(dāng)然全部都是js代碼。既然是js代碼那么就可以使用babel的parser函數(shù)將組件函數(shù)的js代碼編譯成AST抽象語(yǔ)法樹(shù),所以第一步就是使用code去調(diào)用babel的parser函數(shù)生成AST抽象語(yǔ)法樹(shù),然后賦值給root變量。

我們?cè)赿ebug終端來(lái)看看得到的AST抽象語(yǔ)法樹(shù)是什么樣的,如下圖:

圖片圖片

從上圖中可以看到在body數(shù)組中有兩項(xiàng),分別對(duì)應(yīng)的就是ChildComp組件函數(shù)和Home組件函數(shù)。

接下來(lái)就是return返回一個(gè)vineFileCtx上下文對(duì)象,對(duì)象上面的幾個(gè)屬性我們需要講一下。

  • root:由.vine.ts文件轉(zhuǎn)換后的AST抽象語(yǔ)法樹(shù)。
  • vineCompFns:數(shù)組中存了文件中定義的多個(gè)vue組件,初始化時(shí)為空數(shù)組。
  • fileMagicCode:是一個(gè)由magic-string庫(kù)new的一個(gè)對(duì)象,對(duì)象中存了在編譯時(shí)生成的js代碼字符串。magic-string是由svelte的作者寫(xiě)的一個(gè)庫(kù),用于處理字符串的JavaScript庫(kù)。它可以讓你在字符串中進(jìn)行插入、刪除、替換等操作,在編譯時(shí)就是利用這個(gè)庫(kù)生成編譯后的js代碼。toString方法返回經(jīng)過(guò)處理后的字符串,前面的runCompileScript函數(shù)中就是最終調(diào)用vineFileCtx.fileMagicCode.toString()方法返回經(jīng)過(guò)編譯階段處理得到的js代碼。

findVineCompFnDecls函數(shù)

我們接著來(lái)看compileVineTypeScriptFile函數(shù)中的第二個(gè)函數(shù)調(diào)用findVineCompFnDecls:

function compileVineTypeScriptFile(
  code: string,
  fileId: string,
  compilerHooks: VineCompilerHooks,
  fileCtxCache?: VineFileCtx,
) {
  // ...省略
  const vineCompFnDecls = findVineCompFnDecls(vineFileCtx.root);
  // ...省略
}

通過(guò)前一步我們拿到了一個(gè)vineFileCtx上下文對(duì)象,vineFileCtx.root中存的是編譯后的AST抽象語(yǔ)法樹(shù)。

所以這一步就是調(diào)用findVineCompFnDecls函數(shù)從AST抽象語(yǔ)法樹(shù)中提取出在.vine.ts文件中定義的多個(gè)vue組件對(duì)象對(duì)應(yīng)的Node節(jié)點(diǎn)。我們?cè)赿ebug終端來(lái)看看組件對(duì)象對(duì)應(yīng)的Node節(jié)點(diǎn)組成的數(shù)組vineCompFnDecls,如下圖:

圖片圖片

從上圖中可以看到數(shù)組由兩個(gè)Node節(jié)點(diǎn)組成,分別對(duì)應(yīng)的是ChildComp組件函數(shù)和Home組件函數(shù)。

doAnalyzeVine函數(shù)

我們接著來(lái)看compileVineTypeScriptFile函數(shù)中的第三個(gè)函數(shù)調(diào)用doAnalyzeVine:

function compileVineTypeScriptFile(
  code: string,
  fileId: string,
  compilerHooks: VineCompilerHooks,
  fileCtxCache?: VineFileCtx,
) {
  // ...省略
  doAnalyzeVine(compilerHooks, vineFileCtx, vineCompFnDecls);
  // ...省略
}

經(jīng)過(guò)上一步的處理我們拿到了兩個(gè)組件對(duì)象的Node節(jié)點(diǎn),并且將這兩個(gè)Node節(jié)點(diǎn)存到了vineCompFnDecls數(shù)組中。

由于組件對(duì)象的Node節(jié)點(diǎn)是一個(gè)標(biāo)準(zhǔn)的AST抽象語(yǔ)法樹(shù)的Node節(jié)點(diǎn),并不能清晰的描述一個(gè)vue組件對(duì)象。所以接下來(lái)就是調(diào)用doAnalyzeVine函數(shù)遍歷組件對(duì)象的Node節(jié)點(diǎn),將其轉(zhuǎn)換為能夠清晰的描述一個(gè)vue組件的對(duì)象,將這些vue組件對(duì)象組成數(shù)組塞到vineFileCtx上下文對(duì)象的vineCompFns屬性上。

我們?cè)赿ebug終端來(lái)看看經(jīng)過(guò)doAnalyzeVine函數(shù)處理后生成的vineFileCtx.vineCompFns屬性是什么樣的,如下圖:

圖片圖片

從上圖中可以看到vineCompFns屬性中存的組件對(duì)象已經(jīng)能夠清晰的描述一個(gè)vue組件,上面有一些我們熟悉的屬性props、slots等。

transformFile函數(shù)

我們接著來(lái)看compileVineTypeScriptFile函數(shù)中的第四個(gè)函數(shù)調(diào)用transformFile:

function compileVineTypeScriptFile(
  code: string,
  fileId: string,
  compilerHooks: VineCompilerHooks,
  fileCtxCache?: VineFileCtx,
) {
  // ...省略
  transformFile(
    vineFileCtx,
    compilerHooks,
    compilerOptions?.inlineTemplate ?? true,
  );
  // ...省略
}

經(jīng)過(guò)上一步的處理后在vineFileCtx上下文對(duì)象的vineCompFns屬性數(shù)組中已經(jīng)存了一系列能夠清晰描述vue組件的對(duì)象。

在前面我們講過(guò)了vineFileCtx.vineCompFns數(shù)組中存的對(duì)象能夠清晰的描述一個(gè)vue組件,但是對(duì)象中并沒(méi)有我們期望的render函數(shù)、setup函數(shù)等。

所以接下來(lái)就需要調(diào)用transformFile函數(shù),遍歷上一步拿到的vineFileCtx.vineCompFns數(shù)組,將所有的vue組件轉(zhuǎn)換成對(duì)應(yīng)的立即調(diào)用函數(shù)。在每個(gè)立即調(diào)用函數(shù)中都會(huì)return一個(gè)__vine組件對(duì)象,并且這個(gè)__vine組件對(duì)象上都有一個(gè)render屬性。

之所以包裝成一個(gè)立即調(diào)用函數(shù),是因?yàn)槊總€(gè)組件都會(huì)生成一個(gè)名為_(kāi)_vine組件對(duì)象,所以才需要立即調(diào)用函數(shù)將作用域進(jìn)行隔離。

我們?cè)赿ebug終端來(lái)看看經(jīng)過(guò)transformFile函數(shù)處理后拿到的js code代碼字符串,如下圖:

圖片圖片

從上圖中可以看到此時(shí)的js code代碼字符串已經(jīng)和我們之前在瀏覽器中看到的編譯后的代碼一模一樣了。

總結(jié)

Vue Vine是一個(gè)vite插件,vite解析每個(gè)模塊時(shí)都會(huì)觸發(fā)插件的transform鉤子函數(shù)。在鉤子函數(shù)中會(huì)去判斷當(dāng)前文件是否以.vine.ts結(jié)尾的,如果不是則return。

在transform鉤子函數(shù)中會(huì)去調(diào)用runCompileScript函數(shù),runCompileScript函數(shù)并不是實(shí)際干活的地方,而是去調(diào)用compileVineTypeScriptFile函數(shù)。

在compileVineTypeScriptFile函數(shù)中先new一個(gè)vineFileCtx上下文對(duì)象,對(duì)象中的root屬性存了由.vine.ts文件轉(zhuǎn)換成的AST抽象語(yǔ)法樹(shù)。

接著就是調(diào)用findVineCompFnDecls函數(shù)從AST抽象語(yǔ)法樹(shù)中找到組件對(duì)象對(duì)應(yīng)的Node節(jié)點(diǎn)。

由于Node節(jié)點(diǎn)并不能清晰的描述一個(gè)vue組件,所以需要調(diào)用doAnalyzeVine函數(shù)將這些Node節(jié)點(diǎn)轉(zhuǎn)換成能夠清晰描述vue組件的對(duì)象。

最后就是遍歷這些vue組件對(duì)象將其轉(zhuǎn)換成立即調(diào)用函數(shù)。在每個(gè)立即調(diào)用函數(shù)中都會(huì)return一個(gè)__vine組件對(duì)象,并且這個(gè)__vine組件對(duì)象上都有一個(gè)render屬性。

責(zé)任編輯:武曉燕 來(lái)源: 前端歐陽(yáng)
相關(guān)推薦

2024-05-22 08:47:41

2025-04-29 00:00:00

超節(jié)點(diǎn)SuperPod大模型

2021-07-22 09:40:10

GitHub代碼開(kāi)發(fā)者

2025-04-29 08:56:36

2015-12-15 13:43:24

volte

2024-11-15 10:03:43

應(yīng)用模板Vue

2021-08-11 07:53:22

Git rejecthint

2020-11-12 09:15:16

GitHubPython開(kāi)發(fā)

2024-04-01 11:52:46

2023-09-07 23:06:07

2016-09-06 19:45:18

javascriptVue前端

2023-09-05 20:17:18

typescriptPropTypesreact

2022-10-24 00:04:57

飛天茅臺(tái)架構(gòu)搶購(gòu)

2023-04-28 09:30:40

vuereact

2018-01-31 15:45:07

前端Vue.js組件

2022-08-29 07:48:27

文件數(shù)據(jù)參數(shù)類(lèi)型

2022-10-17 08:03:47

封裝vue組件

2024-08-13 09:26:07

2010-04-19 17:21:36

Oracle寫(xiě)文件

2018-09-18 10:11:21

前端vue.jsjavascript
點(diǎn)贊
收藏

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

日韩美女一级视频| 九色91popny| 中文字幕福利视频| 日韩精品久久| 欧美日本在线一区| 亚洲巨乳在线观看| 国产精品区在线观看| 一区二区日韩欧美| 91精品国产色综合久久不卡蜜臀 | 欧美1区二区| 99综合电影在线视频| 欧美有码在线观看| 国产午夜精品久久久久久久久| 久久精品国产福利| 亚洲视频自拍| 国产欧美一区二区三区在线看蜜臀| 国产精品大陆在线观看| 欧美福利第一页| 国产精品免费精品自在线观看| 亚洲综合色成人| 日本日本精品二区免费| 国产亲伦免费视频播放| 欧美天堂亚洲电影院在线观看 | 久久久精品影视| 成人精品久久久| 久久久久久av无码免费网站| 人人九九精品视频| 色素色在线综合| 日本三级中文字幕在线观看| 国产一区不卡在线| 久久xxxx| 亚洲网站视频福利| 一级片免费在线观看视频| 好吊日av在线| 中文字幕国产一区二区| 国产成人亚洲欧美| 天天综合久久综合| 中文字幕丰满孑伦无码专区| 日韩精品一区二区三区| 综合自拍亚洲综合图不卡区| 久久精品国产综合精品| 这里只有精品6| 亚洲大胆在线| 欧美大码xxxx| 国产免费一区二区三区网站免费| 牛牛精品成人免费视频| 精品国产露脸精彩对白 | 亚洲第一网站| 欧美日韩ab片| 26uuu成人网| 99re66热这里只有精品8| 亚洲区在线播放| 青青草视频播放| 国产伦精品一区二区三区免费优势| 在线播放中文字幕一区| 老司机午夜性大片| 四虎精品一区二区免费| 欧美三级中文字| 天天爽夜夜爽一区二区三区 | 成人黄色免费看| 91精品国产乱码久久| 麻豆精品国产传媒mv男同| 国产精品日韩精品| 亚洲自拍偷拍另类| 精品一区二区三区免费观看| 国产在线一区二区三区| 国产乱码久久久| 国产一区二区精品久久91| 亚洲自拍小视频| 亚洲女人18毛片水真多| 成人h精品动漫一区二区三区| 动漫美女被爆操久久久| 男人天堂综合网| 成人黄页毛片网站| 欧美日韩综合精品| 在线免费观看黄色av| 国产精品网站在线观看| 成人手机视频在线| 欧美寡妇性猛交xxx免费| 亚洲第一狼人社区| 成人在线观看黄| aaaa欧美| 日韩一级片网站| 国产一卡二卡三卡四卡| 尤物tv在线精品| 日韩小视频在线| 麻豆成人在线视频| 国产欧美一级| 国产精品综合网站| 亚洲AV无码精品色毛片浪潮| 91色porny蝌蚪| 亚洲人体一区| 日日夜夜天天综合入口| 婷婷综合另类小说色区| 日本999视频| 4438全国亚洲精品观看视频| 精品一区精品二区| 亚洲一区电影在线观看| 亚洲精品乱码| 国产中文日韩欧美| 天天操天天操天天| 国产精品视频看| 欧美一二三不卡| 成人日韩精品| 精品国产乱码久久| eeuss中文字幕| 国产亚洲毛片在线| 91久久精品美女高潮| 亚洲 小说区 图片区 都市| 国产精品久久久久久久浪潮网站| 国产一级做a爰片久久毛片男| 玛雅亚洲电影| 欧美成人video| 最新日韩免费视频| 国产精品呻吟| 国产精品国产亚洲精品看不卡15 | 欧美精品videosex性欧美| 国产第一页在线观看| 国产99久久精品| 亚洲v国产v| 51漫画成人app入口| 欧美日韩国产精选| 无码熟妇人妻av| 亚洲天堂成人| 91麻豆国产语对白在线观看| 精品成人一区二区三区免费视频| 亚洲午夜日本在线观看| 岛国av免费在线| 国产一区二区三区四区大秀| 久久久人成影片一区二区三区| 亚洲综合免费视频| 国产午夜精品理论片a级大结局| 国产精品久久久久9999爆乳| 国产精品国产亚洲精品| 在线视频免费一区二区| 手机看片久久久| 99久久综合色| 日韩网站在线免费观看| 精品国产乱码久久久久久樱花| 中文字幕精品av| 久久久精品毛片| 91网站最新网址| 成年人午夜视频在线观看| 亚洲综合网站| 欧美激情精品久久久久久蜜臀| ,一级淫片a看免费| 国产精品免费久久久久| 亚洲一级免费在线观看| 成人一区而且| 国产伦精品免费视频| 最近高清中文在线字幕在线观看| 色av综合在线| 国产18无套直看片| 日韩av中文在线观看| 欧美日韩一区二区视频在线 | 国产欧美va欧美va香蕉在线| 成人精品福利| 欧美日韩激情一区| 影音先锋男人资源在线观看| 麻豆视频一区二区| 欧美 日韩 国产 在线观看| **精品中文字幕一区二区三区| www日韩欧美| 国产精品怡红院| 亚洲欧美色综合| 国产a级片视频| 亚洲国产午夜| 蜜桃精品久久久久久久免费影院| 原纱央莉成人av片| 中文字幕日韩精品在线| 一级片免费网站| 一区二区三区波多野结衣在线观看| 国产又粗又猛又爽又黄| 亚洲高清自拍| 女人一区二区三区| 欧美日韩卡一| 久久久久中文字幕2018| 亚洲欧美日本在线观看| 91成人免费在线视频| 久久精品日韩无码| 高清成人在线观看| 日韩毛片在线免费看| 久久久久久久久久久9不雅视频| 91免费国产网站| sm在线播放| 色悠悠久久久久| 亚洲狼人综合网| 色老汉一区二区三区| 夫妻性生活毛片| 99精品视频一区| 三级av免费观看| 亚洲精品激情| 一本一生久久a久久精品综合蜜| 成人精品毛片| 国产精品丝袜视频| 国产青草视频在线观看| 一区二区电影免费观看| 久久精品国产91精品亚洲| 日本黄色三级视频| 欧美日韩亚洲综合一区二区三区 | 福利在线视频导航| 日韩免费高清视频| 91黑人精品一区二区三区| 亚洲最新视频在线播放| 69精品无码成人久久久久久| 国产成人在线看| 天天干天天操天天做| 国产毛片久久| 日本国产中文字幕| 日韩精品影视| 欧美h视频在线| 日韩中文字幕视频网| 国产精品久久久久久久久久久不卡 | 高清不卡一区二区| 精品亚洲一区二区三区四区| 中文一区在线| 欧美大黑帍在线播放| 999国产精品永久免费视频app| 久久久影院一区二区三区| 国产精品成人3p一区二区三区| 国产成人精品一区二区在线| 波多野结衣中文在线| 久久久国产在线视频| 粉嫩av一区| 亚洲男人天堂2023| 欧美一级特黄aaaaaa大片在线观看| 欧美剧情片在线观看| 国产乱码77777777| 欧美视频一区二区三区…| 国产一级生活片| 一区二区三区四区国产精品| 四虎地址8848| 国产精品久久久久久一区二区三区| 久久精品一区二区免费播放 | 欧美巨大xxxx做受沙滩| 日韩有码片在线观看| 在线免费av电影| 中文字幕日韩精品有码视频| 国产黄色免费在线观看| 亚洲欧美一区二区精品久久久| 天天操天天操天天| 亚洲电影免费观看高清完整版在线| 国产激情久久久久久熟女老人av| 欧美久久久久久蜜桃| 亚洲自拍偷拍另类| 欧美人体做爰大胆视频| 在线观看色网站| 欧美丰满嫩嫩电影| 一区二区三区精彩视频| 国产精品1区2区3区| 国内精品久久久久久久久| 韩国av网站在线| 久久国产一区二区三区| 黄页视频在线播放| 美女国内精品自产拍在线播放| 久草资源在线| 久久影院资源网| 色爱综合区网| 2019亚洲男人天堂| 都市激情亚洲一区| 国产精品成人久久久久| 成人国产精选| 91在线高清免费观看| 日韩高清在线观看一区二区| 99re视频| 色婷婷狠狠五月综合天色拍 | 亚洲在线观看网站| 国产剧情在线观看一区二区| 国产男女无遮挡猛进猛出| 国产精品911| 亚洲精品国产成人av在线| 99久久国产综合精品女不卡| 欧美激情aaa| 国产精品久99| 久久久久亚洲av成人片| 狠狠躁夜夜躁人人躁婷婷91| 久操视频在线免费观看| 欧美精品成人一区二区三区四区| 精品黑人一区二区三区在线观看| 日韩电影大全免费观看2023年上 | 欧美成人午夜激情| 白浆在线视频| 国产欧美一区二区三区视频 | 日韩精品极品视频免费观看| 国模吧精品人体gogo| 久久精品久久久久| 春色校园综合激情亚洲| 国产精自产拍久久久久久| 91麻豆精品国产91久久久久推荐资源| 久久人人爽爽人人爽人人片av| av中文一区| 久久国产精品网| 蜜臀精品久久久久久蜜臀| 国产在线观看免费播放| 国产亚洲精品超碰| 久久久久久久久久99| 91激情在线视频| 亚洲免费不卡视频| 中文字幕av一区二区三区谷原希美| 特级毛片在线| 国产欧美日韩视频| 欧美日韩精品一区二区三区在线观看| 亚洲欧洲一区二区福利| 亚洲美女少妇无套啪啪呻吟| 在线能看的av网站| 久久影音资源网| 国产一级在线播放| 欧美日本国产视频| 国产一二三区在线视频| 久久久亚洲国产天美传媒修理工| 成人国产网站| 国产区一区二区| 97精品中文字幕| 岛国大片在线播放| 经典一区二区三区| 国产a级黄色片| 亚洲免费观看高清完整版在线观看熊| www成人在线| 欧美成人艳星乳罩| 91xxx在线观看| 欧美精品久久一区二区| 9.1麻豆精品| 欧美一区亚洲二区| 在线亚洲自拍| 国产成人精品一区二区三区在线观看| 久久色.com| 免费在线观看黄网站| 欧美一级二级三级蜜桃| 成年人在线视频| 国产精品91在线| 中文久久电影小说| 久久人妻无码一区二区| 免费看欧美女人艹b| 在线观看视频你懂得| 成人欧美一区二区三区小说| 成人h动漫精品一区二区下载| 日韩精品免费在线视频| 日本无删减在线| 国产精品久久久久久婷婷天堂 | 欧美另类视频在线| 亚洲久久一区| 性猛交╳xxx乱大交| 亚洲精品中文在线影院| 国产剧情精品在线| 色妞欧美日韩在线| 国产精品无码久久久久| 日本一区视频在线播放| 亚洲一区国产| 最新中文字幕视频| 欧美日韩免费在线观看| 深夜影院在线观看| 992tv在线成人免费观看| 日韩中文字幕无砖| 国产精品日韩三级| 国产精品一二一区| 国产一级片免费观看| 日韩欧美www| 女厕盗摄一区二区三区| 精品国产免费一区二区三区 | 熟女少妇在线视频播放| 不卡电影一区二区三区| 国产污片在线观看| 精品视频偷偷看在线观看| freexxx性亚洲精品| 91偷拍精品一区二区三区| 激情综合电影网| 在线观看亚洲免费视频| 欧美日韩一二三四五区| 欧美3p视频在线观看| 国产成人自拍视频在线观看| 沈樵精品国产成av片| 999在线免费视频| 亚洲卡通欧美制服中文| www.av黄色| 欧美一区三区三区高中清蜜桃| 深爱激情久久| 手机免费av片| 一区二区高清免费观看影视大全| 亚洲精品喷潮一区二区三区| 欧美性资源免费| 精品九九在线| 中文字幕无人区二| 欧美日韩性视频| 在线观看免费版| 91久久偷偷做嫩草影院| 午夜亚洲福利| 素人fc2av清纯18岁| 欧美亚日韩国产aⅴ精品中极品| 国产福利视频在线| 国产精品久久7| 青青草成人在线观看| 国产稀缺精品盗摄盗拍| 欧美成人乱码一区二区三区| 欧美亚洲韩国| 在线观看欧美激情| 91在线小视频| 一级做a爱片性色毛片| 午夜精品福利电影| 日本精品三区| 少妇光屁股影院|