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

一文帶你進入微前端世界

開發(fā) 前端
微前端架構(gòu)旨在解決單體應(yīng)用在一個相對長的時間跨度下,由于參與的人員、團隊的增多、變遷,從一個普通應(yīng)用演變成一個巨石應(yīng)用(Frontend Monolith)后,隨之而來的應(yīng)用不可維護的問題。

什么是微前端

微前端(Micro-Frontends)是一種類似于微服務(wù)的架構(gòu),它將微服務(wù)的理念應(yīng)用于瀏覽器端,即將 Web 應(yīng)用由單一的單體應(yīng)用轉(zhuǎn)變?yōu)槎鄠€小型前端應(yīng)用聚合為一的應(yīng)用。微前端(micro-frontends)術(shù)語在 2016 年在 TECHNOLOGY RADAR[1] 中被提及。

微前端架構(gòu)具備以下的特點:

  • 技術(shù)棧無關(guān)。主框架不限制接入應(yīng)用的技術(shù)棧,微應(yīng)用具備完全自主權(quán)
  • 獨立開發(fā)、獨立部署。微應(yīng)用倉庫獨立,前后端可獨立開發(fā),部署完成后主框架自動完成同步更新
  • 增量升級。在面對各種復(fù)雜場景時,我們通常很難對一個已經(jīng)存在的系統(tǒng)做全量的技術(shù)棧升級或重構(gòu),而微前端是一種非常好的實施漸進式重構(gòu)的手段和策略
  • 獨立運行時。每個微應(yīng)用之間狀態(tài)隔離,運行時狀態(tài)不共享

微前端解決了什么問題?

微前端架構(gòu)旨在解決單體應(yīng)用在一個相對長的時間跨度下,由于參與的人員、團隊的增多、變遷,從一個普通應(yīng)用演變成一個巨石應(yīng)用(Frontend Monolith)后,隨之而來的應(yīng)用不可維護的問題。比如:

  • 原本一個團隊管理的項目,后面多個團隊進行管理
  • 隨著項目的體積變大,編譯的速度變長,研發(fā)效率降低
  • 項目變大,系統(tǒng)的復(fù)雜度也會隨之變大,可維護性越來越低,重構(gòu)成本越來越大
  • ...

通過微前端拆分成一個容器應(yīng)用和多個子應(yīng)用之后,各個應(yīng)用能夠獨立部署,相互之間隔離,從而做到:

  • 研發(fā)效率提升:多業(yè)務(wù)線并行開發(fā),團隊自治,獨立迭代
  • 運維風(fēng)險降級:變更范圍縮小
  • 技術(shù)選擇增多:各個應(yīng)用可以選擇更加適合自身的技術(shù)棧
  • 重構(gòu)風(fēng)險降低:低風(fēng)險局部替換,漸進式完成大規(guī)模重構(gòu)
  • ...

微前端實現(xiàn)方案

對比Nginx路由轉(zhuǎn)發(fā)

通過Nginx配置反向代理來實現(xiàn)不同路徑映射到不同應(yīng)用,例如www.abc.com/app1對應(yīng)app1,www.abc.com/app2對應(yīng)app2,這種方案本身并不屬于前端層面的改造,更多的是運維的配置。

優(yōu)點:

  1. 簡單,快速,易配置

缺點:

  1. 在切換應(yīng)用時會觸發(fā)瀏覽器刷新,影響體驗

iframe嵌套

父應(yīng)用單獨是一個頁面,每個子應(yīng)用嵌套一個iframe,父子通信可采用postMessage或者contentWindow方式。

優(yōu)點:

  • 實現(xiàn)簡單,子應(yīng)用之間自帶沙箱,天然隔離,互不影響

缺點:

  • url 不同步。瀏覽器刷新 iframe url 狀態(tài)丟失、后退前進按鈕無法使用。
  • UI 不同步,DOM 結(jié)構(gòu)不共享。想象一下屏幕右下角 1/4 的 iframe 里來一個帶遮罩層的彈框,同時我們要求這個彈框要瀏覽器居中顯示,還要瀏覽器 resize 時自動居中..
  • 全局上下文完全隔離,內(nèi)存變量不共享。iframe 內(nèi)外系統(tǒng)的通信、數(shù)據(jù)同步等需求,主應(yīng)用的 cookie 要透傳到根域名都不同的子應(yīng)用中實現(xiàn)免登效果。
  • 慢。每次子應(yīng)用進入都是一次瀏覽器上下文重建、資源重新加載的過程。

Web Components

每個子應(yīng)用需要采用純Web Components技術(shù)編寫組件,是一套全新的開發(fā)模式

優(yōu)點:

  • 每個子應(yīng)用擁有獨立的script和css,也可單獨部署

缺點:

  • 對于歷史系統(tǒng)改造成本高,子應(yīng)用通信較為復(fù)雜易踩坑

webpack5 的 Module Federation

使用 Module Federation,我們可以在一個應(yīng)用中動態(tài)加載并執(zhí)行另一個應(yīng)用的代碼,且與技術(shù)棧無關(guān),并且能夠共享模塊,從而減小編譯時間以及降低包體積。

優(yōu)點:

  • 能夠共享模塊,減小編譯時間以及降低包體積

缺點:

  • 需要升級 webpack5,構(gòu)建工具受限

組合式應(yīng)用路由分發(fā)

每個子應(yīng)用獨立構(gòu)建和部署,運行時由父應(yīng)用來進行路由管理,應(yīng)用加載,啟動,卸載,以及通信機制。

優(yōu)點:

  • 純前端改造,體驗良好,可無感知切換,子應(yīng)用相互隔離

缺點:

  • 需要設(shè)計和開發(fā),由于父子應(yīng)用處于同一頁面運行,需要解決子應(yīng)用的樣式?jīng)_突,變量對象污染,通信機制等技術(shù)點

組合式應(yīng)用路由分發(fā)是目前業(yè)內(nèi)普遍使用的一種方案,并且能夠滿足大部分需求,接下來我們詳細來看看這種實現(xiàn)方式。

組合式應(yīng)用路由分發(fā)的微前端實現(xiàn)思路

該方案使用的是基座模式,通過一個主應(yīng)用(基座應(yīng)用-Main APP),來管理其它應(yīng)用(子應(yīng)用-MicroAPP)。基座應(yīng)用大多數(shù)是一個前端 SPA 項目,主要負責(zé)應(yīng)用注冊,路由映射,消息下發(fā)等,而微應(yīng)用是獨立前端項目,這些項目不限于采用 React,Vue,Angular 或者 JQuery 開發(fā),每個微應(yīng)用注冊到基座應(yīng)用中,由基座進行管理,但是如果脫離基座也是可以單獨訪問。

圖片

當(dāng)整個微前端框架運行之后,給用戶的體驗就是類似下圖所示:

圖片

簡單描述下就是基座應(yīng)用中有一些菜單項,點擊每個菜單項可以展示對應(yīng)的微應(yīng)用,這些應(yīng)用的切換是純前端無感知的

上面的實現(xiàn)過程主要如下:

  • 獲取注冊表和進行初始化,這些都是在基座應(yīng)用中進行的。
  • 路由分發(fā)。在瀏覽器路徑發(fā)生變化后,基座應(yīng)用會監(jiān)聽 hashchange 或者 popstate 事件,從而獲取到路由切換的時機。通過查詢注冊信息可以獲取到轉(zhuǎn)發(fā)到那個微應(yīng)用,經(jīng)過一些邏輯處理后,采用修改hash方法或者pushState方法來路由信息推送給微應(yīng)用的路由,微應(yīng)用可以是手動監(jiān)聽hashchange或者popstate事件接收,或者采用React-router,vue-router接管路由,后面的邏輯就由微應(yīng)用自己控制。
  • 遠程拉取資源,加載應(yīng)用。這里一般有通過 JavaScript Entry 或者 HTML Entry 作為渲染入口。

注意:子應(yīng)用也可以將包打成多個,然后利用 webpack 的 webpack-manifest-plugin 插件打包出 manifest.json
文件,生成一份資源清單,然后主應(yīng)用的 loadApp 遠程讀取每個子應(yīng)用的清單文件,依次加載文件里面的資源;不過該方案也沒辦法享受子應(yīng)用的按需加載能力。

  • HTML Entry。則更加靈活,直接將子應(yīng)用打出來 HTML 作為入口,主框架可以通過 fetch html 的方式獲取子應(yīng)用的靜態(tài)資源,同時將 HTML document 作為子節(jié)點塞到主框架的容器中。這樣不僅可以極大的減少主應(yīng)用的接入成本,子應(yīng)用的開發(fā)方式及打包方式基本上也不需要調(diào)整,而且可以天然的解決子應(yīng)用之間樣式隔離的問題(后面提到)。這種方案可以通過 。
  • JavaScript Entry。通常是子應(yīng)用將資源打成一個 entry script。但這個方案的限制也頗多,如要求子應(yīng)用的所有資源打包到一個 js bundle 里,包括 css、圖片等資源。除了打出來的包可能體積龐大之外的問題之外,資源的并行加載等特性也無法利用上。

微前端的應(yīng)用隔離

CSS 隔離

當(dāng)主應(yīng)用和微應(yīng)用同屏渲染時,就可能會有一些樣式會相互污染,可以采取以下兩種方案:

  • CSS Module
  • 命名空間,通過 webpack 的 postcss 插件,在打包時添加特定的前綴,即各個子應(yīng)用使用特定的前綴來命名 class。但對于一些插入到 body 中的樣式,比如 element UI 的 Popover 彈出框,這種就特殊處理。

而對于微應(yīng)用與微應(yīng)用之間的CSS隔離就非常簡單,在每次應(yīng)用加載時,將該應(yīng)用所有的link和style 內(nèi)容進行標(biāo)記。在應(yīng)用卸載后,同步卸載頁面上對應(yīng)的link和style即可。

JavaScript 隔離

每當(dāng)微應(yīng)用的 JavaScript 被加載并運行時,它的核心實際上是對全局對象 Window 的修改以及一些全局事件的改變,例如 jQuery 這個 js 運行后,會在 Window 上掛載一個 window.$ 對象,對于其他庫 React,Vue 也不例外。為此,需要在加載和卸載每個微應(yīng)用的同時,盡可能消除這種沖突和影響,最普遍的做法是采用沙箱機制(SandBox)。

沙箱機制的核心是讓局部的 JavaScript 運行時,對外部對象的訪問和修改處在可控的范圍內(nèi),即無論內(nèi)部怎么運行,都不會影響外部的對象。通常在 Node.js 端可以采用 vm 模塊,而對于瀏覽器,則需要結(jié)合 with 關(guān)鍵字和 window.Proxy 對象來實現(xiàn)瀏覽器端的沙箱。

微前端的消息通信

微前端通常不會限制應(yīng)用采用的框架,如何在不同的應(yīng)用,框架之間進行通信是一個需要仔細考量的決定。應(yīng)用間通信有很多種方式,當(dāng)然,要讓多個分離的微應(yīng)用之間要做到通信,本質(zhì)上仍離不開中間媒介或者說全局對象。

自定義事件

通過事件[3]進行通信應(yīng)該是最簡單、通用的方案了。

// 監(jiān)聽事件
window.addEventListener('message', (event) => {
// 處理事件
});

// 觸發(fā)事件
window.dispatchEvent(new CustomEvent('message', { detail: input.value }))

發(fā)布-訂閱

消息訂閱(pub/sub)模式的通信機制是非常適用的,在基座應(yīng)用中會定義事件中心Event,每個微應(yīng)用分別來注冊事件,當(dāng)被觸發(fā)事件時再有事件中心統(tǒng)一分發(fā),這就構(gòu)成了基本的通信機制。

import { Observable } from 'windowed-observable';

const observable = new Observable('konoha');
observable.subscribe((ninja) => {
console.log(ninja)
})

observable.publish('Uchiha Shisui');

Web Workers

通過 Web Workers 進行事件通信。

import Worky from 'worky'
const worker = new Worky("some-worker.js");

worker.on("eventName", function (some, data) {
// 處理
});
worker.emit("someEvent", and, some, data);

共享狀態(tài)

主應(yīng)用創(chuàng)建 state store,共享給子應(yīng)用使用,適用于主、子應(yīng)用技術(shù)棧相同的場景。

總結(jié)

微前端是一種將單個巨型應(yīng)用轉(zhuǎn)變?yōu)槎鄠€微型應(yīng)用聚合為一的應(yīng)用,能夠解決“巨石應(yīng)用”的維護性問題。實現(xiàn)微前端的方式有很多種,每種方案都需要考慮應(yīng)用隔離和應(yīng)用通信的問題,目前較為普遍使用的是組合式路由分發(fā)的方式。

參考

  • 微前端(一)- 理念篇[4]
  • 微前端-最容易看懂的微前端知識[5]
  • 微前端在解決什么問題?[6]
  • 微前端如何落地[7]
  • 微前端解決方案[8]
  • HTML Entry 源碼分析[9]

參考資料

[1]TECHNOLOGY RADAR:
https://www.thoughtworks.com/zh-cn/radar/techniques/micro-frontends

[2]import-html-entry:
https://www.npmjs.com/package/import-html-entry

[3]事件:
https://developer.mozilla.org/en-US/docs/Web/API/CustomEvent

[4]微前端(一)- 理念篇:
https://www.lumin.tech/blog/micro-frontends-1-concept/

[5]微前端-最容易看懂的微前端知識:
https://juejin.cn/post/6844904162509979662

[6]微前端在解決什么問題?:
https://cloud.tencent.com/developer/article/1546556

[7]微前端如何落地:
https://www.infoq.cn/article/xm_aaiotxmlppgwvx9y9

[8]微前端解決方案:
https://segmentfault.com/a/1190000040275586

[9]HTML Entry 源碼分析:
https://juejin.cn/post/6885212507837825038#heading-6

責(zé)任編輯:武曉燕 來源: 前端雜貨鋪
相關(guān)推薦

2021-10-13 21:43:18

JVMRPC框架

2023-11-20 08:18:49

Netty服務(wù)器

2022-12-20 07:39:46

2023-12-21 17:11:21

Containerd管理工具命令行

2023-07-31 08:18:50

Docker參數(shù)容器

2021-05-29 10:11:00

Kafa數(shù)據(jù)業(yè)務(wù)

2022-11-11 19:09:13

架構(gòu)

2023-11-06 08:16:19

APM系統(tǒng)運維

2023-11-03 15:05:41

2023-10-27 08:15:45

2023-11-08 08:15:48

服務(wù)監(jiān)控Zipkin

2022-02-24 07:34:10

SSL協(xié)議加密

2025-03-17 08:15:00

AI技術(shù)模型

2022-05-16 10:49:28

網(wǎng)絡(luò)協(xié)議數(shù)據(jù)

2023-03-06 21:29:41

mmap技術(shù)操作系統(tǒng)

2022-04-08 09:01:14

CSS自定義屬性前端

2020-11-27 09:40:53

Rollup前端代碼

2021-09-13 22:34:56

區(qū)塊鏈新基建數(shù)字化轉(zhuǎn)型

2019-06-13 21:31:19

AI

2024-05-22 09:45:49

點贊
收藏

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

亚洲精品成人久久电影| 亚洲乱码日产精品bd| 国产精品扒开腿做爽爽爽的视频| 综合 欧美 亚洲日本| 久久伊人精品| 色综合久久中文字幕综合网| 一区二区精品国产| 人妻精品无码一区二区| 日韩电影免费在线| 久久久久久久久久久av| 久久视频精品在线观看| 国产在线精品91| 日韩av片在线播放| 欧美超碰在线| 日韩精品日韩在线观看| 韩国一区二区在线播放| 亚洲优女在线| 亚洲精品自拍动漫在线| 欧美一区二区在线| 囯产精品一品二区三区| 蜜臀91精品一区二区三区| 97色在线视频观看| 欧美日韩人妻精品一区二区三区| 激情婷婷综合| 精品五月天久久| 四虎精品一区二区| 日本精品视频| 欧美日韩国产乱码电影| 男人天堂成人在线| 亚洲欧美电影| 亚洲福利国产精品| 免费日韩在线观看| a视频网址在线观看| 久久嫩草精品久久久久| 亚洲影影院av| 国产又黄又大又粗的视频| 老牛影视一区二区三区| 97成人超碰免| 久久久久久久极品| 在线日韩视频| 91精品国产高清久久久久久久久| 极品颜值美女露脸啪啪| 亚洲天堂一区二区三区四区| 中文字幕欧美日韩| 丰满的亚洲女人毛茸茸| 精品欧美激情在线观看| 一区二区欧美激情| 免费看裸体网站| 欧美熟乱15p| 亚洲性av网站| 日本一二三不卡视频| 久久99高清| 一本色道久久综合亚洲精品小说 | 国产精品一二三视频| 波多野结衣视频播放| 中文字幕久久精品一区二区| 欧美白人最猛性xxxxx69交| 国产乱叫456| 欧美成人精品午夜一区二区| 日韩欧美亚洲国产另类| 一级黄色大片免费看| 粉嫩av一区二区| 欧美电影免费提供在线观看| 成人一区二区三区仙踪林| 中文在线免费一区三区| 亚洲精品aⅴ中文字幕乱码| 给我免费观看片在线电影的| 日韩高清一级| 亚洲香蕉av在线一区二区三区| 日本一二三不卡视频| 亚洲高清资源在线观看| 欧美精品在线免费观看| 久久久久久免费观看| 亚洲日本久久| 日本国产欧美一区二区三区| 亚洲图片小说视频| 国产成人无遮挡在线视频| 国产偷国产偷亚洲高清97cao| 午夜小视频在线播放| 国产亚洲va综合人人澡精品| 自拍视频一区二区三区| 毛片在线导航| 色播五月激情综合网| 国产永久免费网站| 国产香蕉精品| 原创国产精品91| 国产精品国产精品88| 在线视频观看日韩| 国产精品一二三视频| 亚洲精品18在线观看| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 日韩中文第一页| 久久久久久久国产视频| 麻豆精品网站| 亚洲综合色av| 午夜国产福利在线观看| 大片免费播放在线视频| 亚洲乱码中文字幕综合| 日韩在线综合网| 天堂久久一区| 日韩精品中文字幕在线| 精品无码久久久久成人漫画| 亚洲欧美bt| 91久久极品少妇xxxxⅹ软件| 可以免费看污视频的网站在线| 亚洲视频中文字幕| 欧美极品欧美精品欧美图片| 秋霞午夜一区二区三区视频| 亚洲九九九在线观看| 欧美被狂躁喷白浆精品| 日本中文一区二区三区| 国产一区高清视频| a级网站在线播放| 91福利视频网站| xxxxxx黄色| 在线看片不卡| 国产欧美精品日韩| 日本黄在线观看| 亚洲免费观看高清在线观看| 国产无套粉嫩白浆内谢的出处| 97久久综合精品久久久综合| www高清在线视频日韩欧美| 日韩黄色在线播放| 粉嫩aⅴ一区二区三区四区五区| 日韩欧美一区二区三区四区五区 | 亚洲av无码一区二区三区性色| 国产精品午夜电影| 国产男女在线观看| 成人h动漫免费观看网站| 日韩一区二区精品视频| 中文字幕二区三区| 国产亚洲女人久久久久毛片| 成人在线免费观看av| 97成人在线| 欧美黄色免费网站| 成人午夜视频一区二区播放| 亚洲三级视频在线观看| 色乱码一区二区三区在线| 国产精品免费不| 欧美一级大胆视频| 你懂的视频在线观看| 高跟丝袜欧美一区| 久久精品国产亚洲精品2020| 亚洲激情中文1区| 91探花福利精品国产自产在线| 国产在线视频网站| 午夜精品aaa| 欧美专区第一页| 神马久久久久久久久久| 亚洲国产一区二区在线播放| 日本人妻一区二区三区| 黄色成人精品网站| 国产麻豆乱码精品一区二区三区 | 久久99久久久久久久噜噜| 国产熟女一区二区丰满| 亚洲人精品午夜| 无码人妻aⅴ一区二区三区玉蒲团| 中文字幕免费一区二区| 99re视频在线| 538视频在线| 日韩电视剧在线观看免费网站| 亚洲黄色三级视频| 国产亚洲精品7777| 亚洲三级在线观看视频| 欧美激情1区| 狠狠久久综合婷婷不卡| av日韩亚洲| 伊人久久综合97精品| 国产麻豆免费观看| 一区二区三区免费观看| 在线观看国产免费视频| 日本在线观看不卡视频| 只有这里有精品| 粉嫩精品导航导航| 日韩女在线观看| 午夜激情在线观看| 欧美大黄免费观看| 黄瓜视频在线免费观看| 国产精品久久久久国产精品日日| 在线视频一二区| 99香蕉国产精品偷在线观看 | 91社区在线观看| 91精品久久久久久蜜臀| 日本在线免费观看| 国产精品色噜噜| 人妻 丝袜美腿 中文字幕| 视频一区视频二区中文字幕| 国产精品区一区二区三| 精品一卡二卡三卡四卡日本乱码| 我爱我色成人网| 麻豆乱码国产一区二区三区| 午夜av免费观看| 欧美二区三区的天堂| 久久久久久久久久影院| 综合在线观看色| 精品少妇一区二区三区免费观| 麻豆久久久久久久| 亚洲熟妇av一区二区三区漫画| 久久中文字幕二区| 精品在线不卡| 精品午夜视频| 国产激情999| h片在线观看下载| zzijzzij亚洲日本成熟少妇| 视频一区二区在线播放| 欧美一区二区三区免费大片 | 日本在线观看不卡视频| 亚洲熟妇无码一区二区三区| 97精品视频| 久久伦理网站| 动漫视频在线一区| 亚洲一区二区在线| 欧美日韩在线精品一区二区三区激情综合 | 最近的2019中文字幕免费一页| 欧美在线精品一区二区三区| 欧美日韩精品欧美日韩精品一 | 秋霞在线午夜| 久久精品国产久精国产一老狼| 青梅竹马是消防员在线| 精品盗摄一区二区三区| 国产免费不卡视频| 日本韩国一区二区| 日韩 欧美 综合| 亚洲制服丝袜在线| 人人澡人人澡人人看| 国产欧美一区二区在线| 国产呦小j女精品视频| 成人免费的视频| 久久久久亚洲av无码专区首jn| 精油按摩中文字幕久久| 亚洲成人av片在线观看| 99成人在线观看| 中文字幕精品一区二区精品绿巨人| 人妻无码中文久久久久专区| 国产99精品视频| 日本r级电影在线观看| 美女任你摸久久| 男女男精品视频站| 免费欧美日韩国产三级电影| 国产精彩免费视频| 日日摸夜夜添夜夜添精品视频| 黑人糟蹋人妻hd中文字幕| 99精品国产福利在线观看免费| 日韩一二区视频| 欧美日韩第一区| 成人午夜免费在线视频| 欧美日韩综合| 可以看毛片的网址| 亚洲啪啪91| 久久国产亚洲精品无码| 国产精品毛片在线| 97视频在线免费播放| 久久久国产精品一区二区中文| 激情综合网婷婷| 免费人成在线不卡| 99re6在线观看| 国产激情一区二区三区| xxxx视频在线观看| 91网站黄www| 91网站免费视频| 欧美高清在线一区| 91视频青青草| 亚洲影视在线观看| 日本一区二区三区精品| 色婷婷综合在线| 国产又粗又猛又爽又黄的视频一 | 亚洲成人国产| 青春草国产视频| 国产日韩欧美一区| 国产精品拍拍拍| 国产一区二区精品久久99| 久久久久无码国产精品一区李宗瑞| 99久久精品免费精品国产| 波多野结衣 在线| 国产精品久久福利| 久久亚洲国产成人精品性色| 一本一本大道香蕉久在线精品| 中文无码精品一区二区三区| 欧美一区二区三区四区五区| 农村少妇久久久久久久| 亚洲三级av在线| 超碰porn在线| 欧美在线视频免费| 91成人在线网站| 国产一区免费观看| 日韩美女一区二区三区在线观看| 成年人视频大全| 美女诱惑黄网站一区| 欧美人交a欧美精品| 亚洲区小说区图片区| 日韩视频在线一区| 国产伦久视频在线观看| 国产精品免费久久久久影院| 一本一道久久a久久| 日韩欧美三级电影| 136国产福利精品导航网址| 亚洲中文字幕久久精品无码喷水| 国产麻豆91精品| 免费污网站在线观看| 亚洲精品五月天| 姑娘第5集在线观看免费好剧| 日韩欧美国产一二三区| 成人精品一区| 欧美一区二区三区免费观看| 亚洲日本中文| 欧美一区二区三区成人久久片| 午夜欧美视频| 狠狠干狠狠操视频| 91女神在线视频| 欧美精品99久久久| 精品污污网站免费看| 外国精品视频在线观看 | 中文字幕+乱码+中文字幕明步| 日韩欧美国产电影| 成人av电影观看| 91tv亚洲精品香蕉国产一区7ujn| 国产精品日本一区二区三区在线 | 无码 人妻 在线 视频| 一区二区三区在线观看动漫| 中文天堂在线播放| 亚洲欧美一区二区三区四区 | 午夜精品爽啪视频| 99久久精品免费看国产交换| 中文亚洲视频在线| 欧洲一级精品| 久久精品一二三区| 国产一区日韩一区| 日本美女久久久| 中文字幕亚洲成人| 在线观看国产一区二区三区| 亚洲全黄一级网站| 樱花草涩涩www在线播放| 国产精品一区二区免费| 欧美午夜不卡| 下面一进一出好爽视频| 亚洲人成网站影音先锋播放| 中文字幕乱码无码人妻系列蜜桃| 亚洲欧美综合v| 天堂网在线最新版www中文网| 国产一区二区三区四区五区在线 | 992kp快乐看片永久免费网址| 26uuu成人网一区二区三区| 久久久在线视频| 日本天码aⅴ片在线电影网站| 91视频免费网站| 亚洲高清影视| 又黄又爽又色的视频| 亚洲免费在线视频| 亚洲精品一区二区三区不卡| 欧美高跟鞋交xxxxxhd| 亚洲视频一起| 成年人看的毛片| 99r精品视频| 亚洲成熟少妇视频在线观看| 亚洲性夜色噜噜噜7777| 91大神在线观看线路一区| 亚洲福利av| 国产一区二区91| 国产在线拍揄自揄拍| 精品国产麻豆免费人成网站| 成年人在线网站| 欧美极品jizzhd欧美| 免费观看成人av| 国产美女久久久久久| 欧美变态凌虐bdsm| 色吧亚洲日本| 性欧美大战久久久久久久免费观看| 久久国内精品视频| 欧美精品入口蜜桃| 日韩av在线网站| 成人看片毛片免费播放器| 法国空姐在线观看免费| 成人免费看黄yyy456| 天干夜夜爽爽日日日日| 日韩有码在线电影| 97色成人综合网站| 国产a视频免费观看| 国产精品久久久久久久蜜臀 | 国产精品成人久久| 国产亚洲欧美日韩精品| 国产精品久久久久久久久久久久久久久 | 国产精品视频福利| 日日夜夜免费精品| 午夜剧场免费在线观看| 亚洲第一男人av| 亚洲天堂1区| 国产情侣第一页| 国产亚洲短视频| 亚洲精品综合久久| 国产精品成av人在线视午夜片| 欧美精品一卡| 欧美 日韩 国产 成人 在线观看 | 国产无套粉嫩白浆在线2022年| 国产综合视频在线观看| 日韩一级在线| 精品国产国产综合精品| 亚洲精品乱码久久久久久金桔影视 | 你懂的免费在线观看| 亚洲一区久久久| 日韩av网站免费在线|