日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

react antd confirm content list_React造轮系列:对话框组件 - Dialog 思路

發(fā)布時(shí)間:2023/12/3 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 react antd confirm content list_React造轮系列:对话框组件 - Dialog 思路 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

React造輪系列:對(duì)話框組件 - Dialog 思路

對(duì)話框一般是我們點(diǎn)擊按鈕彈出的這么一個(gè)東西,主要類型有 Alter, Confirm 及 Modal, Modal 一般帶有半透明的黑色背景。當(dāng)然外觀可參考 AntD 或者 Framework 等。

確定 API

API 方面主要還是要參考同行,因?yàn)槿绻幸惶?#xff0c;別人想你用的UI框架時(shí),你的 API 跟他之前常用的又不用,這樣就加大了入門門檻,所以API 盡量保持跟現(xiàn)有的差不多。

對(duì)話框除了提供顯示屬性外,還要有點(diǎn)擊確認(rèn)后的回放函數(shù),如:

alert('你好').then(fn)confirm('確定?').then(fn)modal(組件名)

實(shí)現(xiàn)

Dialog 源碼已經(jīng)上傳到這里(https://github.com/qq449245884/frank-react2-test)。

dialog/dialog.example.tsx, 這里 state ,生命周期使用 React 16.8 新出的 Hook,如果對(duì) Hook 不熟悉可以先看官網(wǎng)文檔。

dialog/dialog.example.tsx

import React, {useState} from 'react'import Dialog from './dialog'export default function () { const [x, setX] = useState(false) return ( {setX(!x)}}>點(diǎn)擊 )}

dialog/dialog.tsx

import React from 'react'interface Props { visible: boolean}const Dialog: React.FunctionComponent = (props) => { return ( props.visible ? dialog : null )}export default Dialog

運(yùn)行效果

顯示內(nèi)容

上述還有問(wèn)題,我們 dialog 在組件內(nèi)是寫死的,我們想的是直接通過(guò)組件內(nèi)包裹的內(nèi)容,如:

// dialog/dialog.example.tsx...hi...

這樣寫,頁(yè)面上是不會(huì)顯示 hi 的,這里 children 屬性就派上用場(chǎng)了,我們需要在 dialog 組件中進(jìn)一步驟修改如下內(nèi)容:

// dialog/dialog.tsx...return ( props.visible ? {props.children} : null)...

顯示遮罩

通常對(duì)話框會(huì)有一層遮罩,通常我們大都會(huì)這樣寫:

// dialog/dialog.tsx...props.visible ? {props.children} : null...

這種結(jié)構(gòu)有個(gè)不好的地方就是點(diǎn)擊遮罩層的時(shí)候要關(guān)閉對(duì)話框,如果是用這種結(jié)構(gòu),用戶點(diǎn)擊任何 div,都相當(dāng)于點(diǎn)擊遮罩層,所以最好要分開(kāi):

// dialog/dialog.tsx... {props.children} ...

由于 React 要求最外層只能有一個(gè)元素, 所以我們多用了一個(gè) div 包裹起來(lái),但是這種方法無(wú)形之中多了個(gè) div,所以可以使用 React 16 之后新出的 Fragment, Fragment 跟 vue 中的 template 一樣,它是不會(huì)渲染到頁(yè)面的。

import React, {Fragment} from 'react'import './dialog.scss';interface Props { visible: boolean}const Dialog: React.FunctionComponent = (props) => { return ( props.visible ? {props.children} : null )}export default Dialog

完善頭部,內(nèi)容及底部

這里不多說(shuō),直接上代碼

import React, {Fragment} from 'react'import './dialog.scss';import {Icon} from '../index'interface Props { visible: boolean}const Dialog: React.FunctionComponent = (props) => { return ( props.visible ? 提示 {props.children} ok cancel : null )}export default Dialog

從上述代碼我們可以發(fā)現(xiàn)我們寫樣式的名字時(shí)候,為了不被第三使用覆蓋,我們自定義了一個(gè) fui-dialog前綴,在寫每個(gè)樣式名稱時(shí),都要寫一遍,這樣顯然不太合理,萬(wàn)一哪天我不用這個(gè)前綴時(shí)候,每個(gè)都要改一遍,所以我們需要一個(gè)方法來(lái)封裝。

咱們可能會(huì)寫這樣方法:

function scopedClass(name) { return `fui-dialog-${name}`}

這樣寫不行,因?yàn)槲覀?name 可能不傳,這樣就會(huì)多出一個(gè) -,所以需要進(jìn)一步的判斷:

function scopedClass(name) { return `fui-dialog-${name ? '-' + name : ''}`}

那還有沒(méi)有更簡(jiǎn)潔的方法,使用 filter 方法:

function scopedClass(name ?: string) { return ['fui-dialog', name].filter(Boolean).join('-')}

調(diào)用方式如下:

... 提示 {props.children} ok cancel ...

大家在想法,這樣寫是有問(wèn)題,每個(gè)組件都寫一個(gè)函數(shù)嗎,如果 Icon 組件,我還需要寫一個(gè)fui-icon, 解決方法是把 前綴當(dāng)一個(gè)參數(shù),如:

function scopedClass(name ?: string) { return ['fui-dialog', name].filter(Boolean).join('-')}

調(diào)用方式如下:

className={scopedClass('fui-dialog', 'mask')}

這樣寫,還不如直接寫樣式,這種方式是等于白寫了一個(gè)方法,那怎么辦?這就需要高階函數(shù)出場(chǎng)了。實(shí)現(xiàn)如下:

function scopeClassMaker(prefix: string) { return function (name ?: string) { return [prefix, name].filter(Boolean).join('-') }}const scopedClass = scopeClassMaker('fui-dialog')

scopeClassMaker 函數(shù)是高級(jí)函數(shù),返回一個(gè)帶了 prefix 參數(shù)的函數(shù)。

事件處理

在寫事件處理之前,我們 Dialog 需要接收一個(gè) buttons 屬性,就是顯示的操作按鈕并添加事件:

// dialog/dialog.example.tsx... {setX(false)}}>1, {setX(false)}}>2, ]}> hi...

咱們看到這個(gè),第一反應(yīng)應(yīng)該是覺(jué)得這樣寫很麻煩,我寫個(gè) dialog, visible要自己,按鈕要自己,連事件也要自己寫。請(qǐng)接受這種設(shè)定。雖然麻煩,但非常的好理解。這跟 Vue 的理念是不太一樣的。當(dāng)然后面會(huì)進(jìn)一步驟優(yōu)化。

組件內(nèi)渲染如下:

{ props.buttons }

運(yùn)行起來(lái)你會(huì)發(fā)現(xiàn)有個(gè)警告:

主要是說(shuō)我們渲染數(shù)組時(shí),需要加個(gè) key,解決方法有兩種,就是不要使用數(shù)組方式,當(dāng)然這不治本,所以這里 React.cloneElemen 出場(chǎng)了,它可以克隆元素并添加對(duì)應(yīng)的屬性值,如下:

{ props.buttons.map((button, index) => { React.cloneElement(button, {key: index}) })}

對(duì)應(yīng)的點(diǎn)擊關(guān)閉事件相對(duì)容易這邊就不講了,可以自行查看源碼。

接下來(lái)來(lái)看一個(gè)樣式的問(wèn)題,首先先給出我們遮罩的樣式:

.fui-dialog { position: fixed; background: white; min-width: 20em; z-index: 2; border-radius: 4px; top: 50%; left: 50%; transform: translate(-50%, -50%); &-mask { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: fade_out(black, 0.5); z-index: 1; } .... 以下省略其它樣式}

我們遮罩 .fui-dialog-mask 使用 fixed 定位感覺(jué)是沒(méi)問(wèn)題的,那如果在調(diào)用 dialog 同級(jí)在加以下這么元素:

666 {setX(!x)}}>點(diǎn)擊...

運(yùn)行效果:

發(fā)現(xiàn)遮罩并沒(méi)有遮住 666 的內(nèi)容。這是為什么?

看結(jié)構(gòu)也很好理解,遮罩元素與 666 是同級(jí)結(jié)構(gòu),且層級(jí)比 666 低,當(dāng)然是覆蓋不了的。那咱們可能就會(huì)這樣做,給 .fui-dialog-mask設(shè)置一個(gè) zIndex 比它大的唄,如 9999。

效果:

恩,感覺(jué)沒(méi)問(wèn)題,這時(shí)我們?cè)?Dialog 組件在嵌套一層 zIndex 為 9 的呢,如:

...

運(yùn)行效果如下:

發(fā)現(xiàn),父元素被壓住了,里面元素 zIndex 值如何的高,都沒(méi)有效果。

那這要怎么破?答案是不要讓它出現(xiàn)在任何元素的里面,這怎么可能呢。這里就需要引出一個(gè)神奇的 API了。這個(gè) API 叫做 傳送門(portal)。

用法如下:

return ReactDOM.createPortal( this.props.children, domNode);

第一個(gè)參數(shù)就是你的 div,第二個(gè)參數(shù)就是你要去的地方。

import React, {Fragment, ReactElement} from 'react'import ReactDOM from 'react-dom'import './dialog.scss';import {Icon} from '../index'import {scopedClassMaker} from '../classes'interface Props { visible: boolean, buttons: Array, onClose: React.MouseEventHandler, closeOnClickMask?: boolean}const scopedClass = scopedClassMaker('fui-dialog')const sc = scopedClassconst Dialog: React.FunctionComponent = (props) => { const onClickClose: React.MouseEventHandler = (e) => { props.onClose(e) } const onClickMask: React.MouseEventHandler = (e) => { if (props.closeOnClickMask) { props.onClose(e) } } const x = props.visible ? 提示 {props.children} { props.buttons.map((button, index) => { React.cloneElement(button, {key: index}) }) } : null return ( ReactDOM.createPortal(x, document.body) )}Dialog.defaultProps = { closeOnClickMask: false}export default Dialog

運(yùn)行效果:

當(dāng)然這樣,如果 Dialog 層級(jí)比同級(jí)的 zIndex 小的話,還是覆蓋不了。 那 zIndex 一般設(shè)置成多少比較合理。一般 Dialog 這層設(shè)置成 1, mask 這層設(shè)置成 2。定的越小越好,因?yàn)橛脩艨梢匀ジ摹?/p>

zIndex 的管理

zIndex 管理一般就是前端架構(gòu)師要做的了,根據(jù)業(yè)務(wù)產(chǎn)景來(lái)劃分,如廣告肯定是要在頁(yè)面最上面,所以 zIndex 一般是屬于最高級(jí)的。

便利的 API 之 Alert

上述我們使用 Dialog 組件調(diào)用方式比較麻煩,寫了一堆,有時(shí)候我們想到使用 alert 直接彈出一個(gè)對(duì)話框這樣簡(jiǎn)單方便。如

example 3

alert('1')}>alert

我們想直接點(diǎn)擊 button ,然后彈出我們自定義的對(duì)話框內(nèi)容為1 ,需要在 Dialog 組件內(nèi)我們需要導(dǎo)出一個(gè) alert 方法,如下:

// dialog/dialog.tsx...const alert = (content: string) => { const component = {}}> {content} const div = document.createElement('div') document.body.append(div) ReactDOM.render(component, div)}export {alert}...

運(yùn)行效果:

但有個(gè)問(wèn)題,因?yàn)閷?duì)話框的 visible 是由外部傳入的,且 React 是單向數(shù)據(jù)流的,在組件內(nèi)并不能直接修改 visible,所以在 onClose 方法我們需要再次渲染一個(gè)新的組件,并設(shè)置新組件 visible 為 ture,覆蓋原來(lái)的組件:

...const alert = (content: string) => { const component = { ReactDOM.render(React.cloneElement(component, {visible: false}), div) ReactDOM.unmountComponentAtNode(div) div.remove() }}> {content} const div = document.createElement('div') document.body.append(div) ReactDOM.render(component, div)}..

便利的 API 之 confirm

confirm 調(diào)用方式:

confirm('1', ()=>{}, ()=> {})}>confirm

第一個(gè)參數(shù)是顯示的內(nèi)容,每二個(gè)參數(shù)是確認(rèn)的回調(diào),第三個(gè)參數(shù)是取消的回調(diào)函數(shù)。

實(shí)現(xiàn)方式:

const confirm = (content: string, yes?: () => void, no?: () => void) => { const onYes = () => { ReactDOM.render(React.cloneElement(component, {visible: false}), div) ReactDOM.unmountComponentAtNode(div) div.remove() yes && yes() } const onNo = () => { ReactDOM.render(React.cloneElement(component, {visible: false}), div) ReactDOM.unmountComponentAtNode(div) div.remove() no && no() } const component = ( { onNo()}} buttons={[yes, no ]} > {content} ) const div = document.createElement('div') document.body.appendChild(div) ReactDOM.render(component, div)}

事件處理跟 Alter 差不多,唯一多了一步就是 confirm 當(dāng)點(diǎn)擊 yes 或者 no 的時(shí)候,如果外部有回調(diào)就需要調(diào)用對(duì)應(yīng)的回調(diào)函數(shù)。

便利的 API 之 modal

modal 調(diào)用方式:

{modal(

你好

)}}>modal

modal 對(duì)應(yīng)傳遞的內(nèi)容就不是單單的文本了,而是元素。

實(shí)現(xiàn)方式:

const modal = (content: ReactNode | ReactFragment) => { const onClose = () => { ReactDOM.render(React.cloneElement(component, {visible: false}), div) ReactDOM.unmountComponentAtNode(div) div.remove() } const component = {content} const div = document.createElement('div') document.body.appendChild(div) ReactDOM.render(component, div)}

注意,這邊的 content 類型。

運(yùn)行效果:

這還有個(gè)問(wèn)題,如果需要加按鈕呢,可能會(huì)這樣寫:

{modal(

你好 close

)}}>modal

這樣是關(guān)不了的,因?yàn)?Dialog 是封裝在 modal 里面的。如果要關(guān),必須控制 visible,那很顯然我從外面控制不了里面的 visible,所以這個(gè) button 沒(méi)有辦法把這個(gè) modal 關(guān)掉。

解決方法就是使用閉包,我們可以在 modal 方法里面把 close 方法返回:

const modal = (content: ReactNode | ReactFragment) => { const onClose = () => { ReactDOM.render(React.cloneElement(component, {visible: false}), div) ReactDOM.unmountComponentAtNode(div) div.remove() } const component = {content} const div = document.createElement('div') document.body.appendChild(div) ReactDOM.render(component, div) return onClose;}

最后多了一個(gè) retrun onClose,由于閉包的作用,外部調(diào)用返回的 onClose 方法可以訪問(wèn)到內(nèi)部變量。

調(diào)用方式:

const openModal = () => { const close = modal(

你好 close()}>close

)}modal

重構(gòu) API

在重構(gòu)之前,我們先要抽象 alert, confirm, modal 中各自的方法:

從表格可以看出,modal 與其它兩個(gè)只多了一個(gè) retrun api,其實(shí)其它兩個(gè)也可以返回對(duì)應(yīng)的 Api,只是我們沒(méi)去調(diào)用而已,所以補(bǔ)上:

這樣一來(lái),這三個(gè)函數(shù)從抽象層面上來(lái)看是類似的,所以這三個(gè)函數(shù)應(yīng)該合成一個(gè)。

首先抽取公共部分,先取名為 x ,內(nèi)容如下:

const x= (content: ReactNode, buttons ?:Array, afterClose?: () => void) => { const close = () => { ReactDOM.render(React.cloneElement(component, {visible: false}), div) ReactDOM.unmountComponentAtNode(div) div.remove() afterClose && afterClose() } const component = { close(); afterClose && afterClose() }} buttons={buttons} > {content} const div = document.createElement('div') document.body.append(div) ReactDOM.render(component, div) return close}

alert 重構(gòu)后的代碼如下:

const alert = (content: string) => { const button = close()}>ok const close = x(content, [button])}

confirm 重構(gòu)后的代碼如下:

const confirm = (content: string, yes?: () => void, no?: () => void) => { const onYes = () => { close() yes && yes() } const onNo = () => { close() no && no() } const buttons = [ yes, no ] const close = modal(content, buttons, no)}

modal 重構(gòu)后的代碼如下:

const modal = (content: ReactNode | ReactFragment) => { return x(content)}

最后發(fā)現(xiàn)其實(shí) x 方法就是 modal 方法,所以更改 x 名為 modal,刪除對(duì)應(yīng)的 modal 定義。

總結(jié)

  • scopedClass 高階函數(shù)的使用
  • 傳送門 portal
  • 動(dòng)態(tài)生成組件
  • 閉包傳 API
  • 本組件為使用優(yōu)化樣式,如果有興趣可以自行優(yōu)化,本節(jié)源碼已經(jīng)上傳至這里(https://github.com/qq449245884/frank-react2-test)中的 lib/dialog。

    總結(jié)

    以上是生活随笔為你收集整理的react antd confirm content list_React造轮系列:对话框组件 - Dialog 思路的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    日韩精品一区二 | 91大神精品视频在线观看 | 欧美精品中文字幕亚洲专区 | 99久高清在线观看视频99精品热在线观看视频 | 最新不卡av| av免费在线免费观看 | 天堂网av 在线| 97品白浆高清久久久久久 | 久草视频国产 | 在线观看电影av | 久久99网站| 精品视频资源站 | 中文字幕资源网 国产 | 美女网站在线 | 中文字幕 国产视频 | 日韩电影精品一区 | 黄色片网站av | 高清久久久 | 麻豆播放 | 91传媒在线| 亚洲精品免费在线播放 | 日韩久久精品一区 | 免费在线激情视频 | 国产精品一区二区 91 | 97品白浆高清久久久久久 | 亚洲97在线 | 欧美激情一区不卡 | 欧美在线18 | 五月婷综合 | 成年人视频在线免费观看 | 国产精品美女视频网站 | 91av中文字幕 | 天天干,狠狠干 | 国产一区二区在线播放视频 | www..com毛片 | 99精品国产一区二区三区麻豆 | 免费观看一级 | 在线免费精品视频 | 国产亚洲精品久久19p | 天天狠狠 | 国产清纯在线 | 久久久久国产成人免费精品免费 | 精品国产一区二区三区在线 | 丁香综合五月 | 亚洲国产中文字幕 | 亚洲视频免费视频 | 日韩精品黄 | 六月婷色 | 国色天香在线 | 在线亚洲精品 | 亚洲丝袜一区二区 | 91精品国产麻豆 | 在线免费观看视频一区二区三区 | 91中文字幕 | 人人舔人人舔 | 视频在线观看国产 | 日韩精品久久久 | 婷婷av网站 | 麻豆 videos| 手机看片99 | 国产成人av一区二区三区在线观看 | 久久精品国产99国产 | 特黄免费av| 免费中文字幕 | 亚洲国产日韩一区 | 欧美精品第一 | 搡bbbb搡bbb视频 | 国产拍在线 | 精品久久久久久亚洲综合网站 | 久久99国产精品久久 | 91人人澡人人爽人人精品 | 久精品在线 | 久久a v电影 | 亚洲区另类春色综合小说 | 欧洲一区二区三区精品 | av免费片 | 一区二区三区韩国免费中文网站 | 精品免费久久 | 中文字幕在线观看资源 | 超碰在线天天 | 欧美色图亚洲图片 | 亚洲美女精品 | www在线观看视频 | 国产在线观看免 | 人人玩人人添人人澡超碰 | 亚洲三级视频 | 欧美精品久久久久久久久久 | 久久成视频 | 久草在线手机视频 | 国产精品久久久久永久免费观看 | 国产精品va最新国产精品视频 | www.天天色 | 免费毛片一区二区三区久久久 | 一区二区三区国 | 久久久久久97三级 | 美女av免费看 | 亚洲精品动漫久久久久 | 精品视频一区在线 | 日日夜夜天天久久 | 日韩四虎| 天天做天天干 | 久久精品99北条麻妃 | 亚洲一区二区三区在线看 | 亚洲电影图片小说 | 成人中文字幕在线观看 | 国产福利专区 | 精品视频97 | 久久99精品国产麻豆婷婷 | 综合精品在线 | 欧美在线一级片 | 好看av在线 | 亚洲爱爱视频 | 久久人人插 | 综合久久久久久久久 | 久久久久久电影 | 少妇bbbb搡bbbb搡bbbb | 国产精品1区2区3区 久久免费视频7 | 日韩色视频在线观看 | 黄色三级久久 | 国产主播99 | 婷婷丁香av | 午夜av激情 | 亚洲精品乱码久久久久久蜜桃欧美 | 精品国产乱码久久久久久浪潮 | 亚洲高清视频一区二区三区 | 三级黄色片子 | 中文字幕a∨在线乱码免费看 | 久久综合色一综合色88 | 欧美激情视频一区二区三区免费 | 久久久免费av| 九九综合九九 | 欧美少妇bbwhd| 天天色天天草天天射 | 国产精品久久久久久爽爽爽 | 日韩电影一区二区在线观看 | 国产成人精品国内自产拍免费看 | 涩涩网站在线播放 | 亚洲成a人片77777潘金莲 | 人人爽人人乐 | 六月丁香综合 | 中文字幕高清视频 | 操操操日日 | 国产九九九九九 | 欧美日韩国产免费视频 | 欧美精品在线观看一区 | 成人毛片100免费观看 | 国产中文字幕在线观看 | 久草影视在线 | 久久精品视频中文字幕 | 亚洲精品一区二区三区高潮 | 婷婷激情5月天 | 久爱综合| 成年人国产视频 | 黄色毛片网站在线观看 | 99久热在线精品视频成人一区 | 美女精品国产 | 日日摸日日碰 | 日韩在线观看第一页 | 久草免费在线观看视频 | 一区二区三区在线免费观看视频 | 久草精品在线 | 免费一级片观看 | 亚洲精品乱码久久久久久按摩 | 91网页版在线观看 | 91视频大全 | 日本aaaa级毛片在线看 | 国产午夜在线观看视频 | 少妇bbw揉bbb欧美 | 久久九九精品 | 精品国模一区二区三区 | 99视频精品免费视频 | 99精品视频网站 | japanesefreesex中国少妇 | 午夜精品一区二区三区在线播放 | 亚洲欧美经典 | 国产激情小视频在线观看 | 国产精品久久久久永久免费看 | 日批视频 | 免费美女av | 成人av网站在线播放 | 波多野结衣在线播放一区 | 狠狠干美女 | 99久久99精品| 国产日韩精品一区二区三区在线 | 美女福利视频一区二区 | 亚洲精品在线观看网站 | 91大神视频网站 | 国产精品扒开做爽爽的视频 | 亚洲成人av电影 | 91丨九色丨高潮丰满 | 久久国产精品视频免费看 | 国产精品美女免费 | 国产不卡在线视频 | 91视频久久久 | 91三级在线观看 | 亚洲午夜久久久久久久久 | 在线小视频 | 亚洲精品视频免费在线 | 欧美影片 | 高清av在线 | 亚洲视频电影在线 | 久久久久亚洲国产 | 人人玩人人添人人澡超碰 | 日韩精品久久中文字幕 | 99热精品在线观看 | 欧美日韩国产网站 | 亚洲成人精品 | 精品久久国产 | 久久免费视频这里只有精品 | 国产人免费人成免费视频 | 日韩精品资源 | 久草视频手机在线 | 欧美久久久久久久久久久久 | 欧美一区二区三区特黄 | 国内精品久久久久久久久久 | 精品99免费视频 | 日日草视频 | 婷婷丁香狠狠爱 | 国内精品毛片 | 久久久69 | 欧美精品乱码久久久久久 | 日日爱999| 一级免费观看 | 久久在线一区 | 午夜国产福利在线 | 国产黄视频在线观看 | 韩日色视频 | 操高跟美女 | 狠狠色伊人亚洲综合成人 | 91日韩在线视频 | 欧美日韩视频网站 | 免费看片成人 | 黄污网站在线 | 最近2019好看的中文字幕免费 | 欧美成年人在线视频 | 国产精品久免费的黄网站 | 成人蜜桃 | 夜夜澡人模人人添人人看 | 国产在线久久久 | 久久精品国产免费看久久精品 | 精品一二三四视频 | 欧美在线观看视频一区二区 | 国产一区免费视频 | 中文字幕一区二区三区四区 | 欧美日韩有码 | 免费在线黄色av | 国产亚洲精品综合一区91 | 在线视频你懂得 | 国产精品久久久久久久久久不蜜月 | 久久字幕精品一区 | 一区二区三区手机在线观看 | 九色91视频| 久久国产精品久久精品 | 欧美成年网站 | 亚洲另类视频 | 成人影视免费看 | a视频免费 | av在线免费观看黄 | 国产资源中文字幕 | 国产视频亚洲视频 | 日本中文字幕在线视频 | 久久久久福利视频 | 91成人看片| 一色屋精品视频在线观看 | 欧美综合久久久 | 丁香花中文字幕 | 国产高清一 | 九九热在线观看视频 | 免费观看国产视频 | www.天天草 | 黄色网免费 | 国产精品久久久久久久久久ktv | 国产一卡二卡四卡国 | 天天狠狠干| 国产自在线 | 97精品国产手机 | 福利视频导航网址 | 99精品热视频 | 久久免费高清视频 | 在线观看中文字幕2021 | 色婷婷电影网 | 久久视频网 | 精品字幕| 操操色| 亚洲女在线 | 国产精品一区久久久久 | 日韩精品高清视频 | 亚洲精品视频在线免费播放 | 黄色软件在线看 | 亚州国产视频 | 亚洲不卡123 | 欧美日韩综合在线观看 | 九九热免费观看 | 免费在线观看黄色网 | 色视频成人在线观看免 | 国产小视频在线播放 | 在线观看国产成人av片 | 在线影视 一区 二区 三区 | 欧美视频99| 99日精品 | 日韩经典一区二区三区 | 成人一区二区在线观看 | 国产精品成人aaaaa网站 | 日本精品久久久一区二区三区 | 色九九在线 | 日本激情动作片免费看 | 亚洲日本韩国一区二区 | 国产精品24小时在线观看 | 久久免费视频99 | 波多野结衣电影一区二区 | 免费特级黄毛片 | 日日激情 | 九九电影在线 | 波多野结衣亚洲一区二区 | 丁香在线视频 | 91麻豆免费看 | 国产精品久久一区二区无卡 | 久久99精品久久只有精品 | 日韩视频中文字幕在线观看 | 午夜久久久久久久久 | 国产美女主播精品一区二区三区 | 中文字幕成人网 | 欧美另类sm图片 | 国产精品久久影院 | 久久成人精品电影 | 韩国av一区二区三区在线观看 | 国产精品久久久久久久久久直播 | 国产毛片久久久 | 久久国产综合视频 | 国产成人精品女人久久久 | 91天堂影院 | 欧美日韩一区二区三区在线免费观看 | 毛片一区二区 | 少妇搡bbbb搡bbb搡忠贞 | 91丨九色丨国产女 | 天天操天天操天天操 | 一区二区不卡高清 | 久久免费美女视频 | 日本在线观看中文字幕 | av超碰免费在线 | 久久久久免费看 | 欧美aaa一级| 青青草国产在线 | 久久草草影视免费网 | 日韩在线视| 亚洲人成免费网站 | 97视频免费观看2区 亚洲视屏 | 天天射天天射 | 综合久久影院 | 国产日产精品久久久久快鸭 | 婷婷在线五月 | 色99在线| 免费色视频网址 | 91片黄在线观看 | 国产成人久久精品亚洲 | 狠狠的日 | 久久精品99国产精品酒店日本 | 久久成人人人人精品欧 | 亚洲国产午夜视频 | 久久精品国产免费看久久精品 | 色网站中文字幕 | 精品资源在线 | 日本中文字幕久久 | 日韩精品久久久久久久电影竹菊 | 在线只有精品 | 四虎成人av | 正在播放亚洲精品 | 美女黄色网在线播放 | 中文字幕日韩有码 | 久久综合干 | 热久久影视 | 99免费| 国产精品岛国久久久久久久久红粉 | 国产一区二区在线观看视频 | 中文字幕乱码日本亚洲一区二区 | 免费看的黄色网 | 国产精彩视频 | 很黄很色很污的网站 | 久久精品精品 | 中文网丁香综合网 | 国产精品黄色在线观看 | 97人人澡人人添人人爽超碰 | 黄色软件在线观看 | 久久九九九九 | 成人h视频 | 精品欧美一区二区三区久久久 | 日p在线观看| 日韩精品综合在线 | 九九热在线视频 | 91在线资源 | 依人成人综合网 | 天天天天天干 | 亚洲桃花综合 | 亚洲精选在线观看 | 激情视频二区 | av一区二区三区在线 | 亚洲欧洲精品视频 | 精品女同一区二区三区在线观看 | www.在线观看视频 | 久久久久久蜜桃一区二区 | 五月激情视频 | 九九久久影视 | 超碰免费观看 | 久久试看 | 999在线精品| 国产成人精品电影久久久 | 综合色站导航 | 99在线精品视频 | 色婷婷综合五月 | 日韩av看片 | 97碰碰精品嫩模在线播放 | av中文字幕在线观看网站 | 亚洲精品人人 | 国产一级黄色免费看 | 国产免费又爽又刺激在线观看 | 久久情爱 | 亚洲午夜久久久久 | 在线观影网站 | www.在线看片.com | 国产成a人亚洲精v品在线观看 | 国产精品入口a级 | 最新av网站在线观看 | 久久色在线观看 | 亚洲精品九九 | 91精品久久久久久久91蜜桃 | 亚洲免费视频观看 | 天天操天天吃 | 99精品热视频 | 亚洲精品乱码久久久一二三 | 麻豆一区在线观看 | 国产视频午夜 | 精品在线观看一区二区 | 久久躁日日躁aaaaxxxx | 99re久久资源最新地址 | 亚洲综合国产精品 | 久久艹人人 | 最新真实国产在线视频 | 日韩欧美在线综合网 | 99久久99久久精品国产片 | 在线韩国电影免费观影完整版 | 中文免费观看 | 91精品久久久久久久久久久久久 | 日韩一区二区三区不卡 | 亚洲午夜久久久综合37日本 | 国产精品一区二区在线观看 | 欧美激情综合五月色丁香小说 | 亚洲精品男人的天堂 | 国产精品久久久久久久久久免费看 | 成人a免费看 | 青青河边草免费直播 | 国产不卡一 | 成人午夜精品 | 国产色在线视频 | 欧美色噜噜 | 国产精品久久麻豆 | 成人av.com | 久久久久免费精品国产 | 欧美成人在线免费 | 综合网成人 | 国产精品二区三区 | 免费黄色特级片 | 中文字幕中文字幕在线中文字幕三区 | 欧美日本在线视频 | www国产亚洲精品久久网站 | 8x成人免费视频 | 久久综合久久综合这里只有精品 | 天天看天天干 | 在线91网 | 亚洲日本在线一区 | 99久久精品久久久久久动态片 | 中文字幕精品一区二区三区电影 | 国产精品视频免费在线观看 | 天天操天天射天天爱 | 久久综合久久综合九色 | 久久久久国产精品厨房 | 午夜三级理论 | 永久精品视频 | 欧美精彩视频在线观看 | 久久视频在线观看免费 | 久久高视频 | 国产爽视频 | 人人干在线 | 少妇视频在线播放 | 国产丝袜制服在线 | 国产精品av电影 | 久久久久免费观看 | 免费看一级黄色 | 成年人在线观看网站 | 涩涩在线| 亚洲爱av| 天天综合亚洲 | 亚洲精品18日本一区app | 久久免费a | 欧美精品久久久久久 | 久久免费毛片视频 | 日韩专区在线 | 亚洲情感电影大片 | 日本性xxx | 天天色欧美| 国产精品丝袜在线 | 在线天堂日本 | 夜夜操天天 | 色资源在线观看 | 国产精品久久久久一区二区国产 | 日韩成人黄色av | 久久久久看片 | 永久免费观看视频 | 国产精品99久久久精品免费观看 | 一级成人免费 | 中文字幕在线日亚洲9 | 成人午夜剧场在线观看 | 奇米影视777影音先锋 | 久草在线综合 | 少妇性xxx | 久久久久久不卡 | 丁香婷婷综合五月 | 免费视频 你懂的 | 91粉色视频 | 正在播放亚洲精品 | 国产成人精品久久亚洲高清不卡 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产成人在线观看免费 | 天堂av在线免费观看 | 国产精品久久一卡二卡 | 久久99中文字幕 | 韩国一区二区在线观看 | 91精品啪在线观看国产81旧版 | 蜜臀久久99精品久久久久久网站 | 蜜桃视频在线观看一区 | 免费网站黄色 | 国产精品久久久精品 | 欧美性另类| 激情五月六月婷婷 | 国产精品你懂的在线观看 | 国产精品九九九九九九 | 精品一区二区三区在线播放 | 日韩手机在线 | 日韩精品一区二区三区在线视频 | 国产一级二级在线播放 | 久久不卡电影 | 国产中文字幕视频在线观看 | 免费观看日韩 | 免费色网站| 午夜久久美女 | 久久久综合精品 | 免费在线国产精品 | 午夜精品在线看 | 国产精品成人久久久久 | 久久人人爽视频 | 91视频91色 | 涩涩色亚洲一区 | 国产少妇在线观看 | 欧美淫视频 | 中文字幕在线看视频 | 激情五月在线视频 | 久久视频这里有久久精品视频11 | 在线视频日韩欧美 | 91超碰免费在线 | 91亚色视频| 综合网在线视频 | 天天操天天摸天天爽 | 国产免费人成xvideos视频 | 亚洲免费成人av电影 | www.亚洲精品在线 | 亚洲国产欧美一区二区三区丁香婷 | 不卡视频在线 | 国产精品久久久久久久免费观看 | 久久综合九色综合久久久精品综合 | 中文区中文字幕免费看 | 深爱五月激情五月 | 在线 国产 亚洲 欧美 | 国产一区二区在线免费播放 | 国产一区二区三区高清播放 | av在线最新 | 国产精品免费在线播放 | 中文字幕在线观看一区 | 国产96在线观看 | 免费日韩高清 | 久久免费视频2 | 69亚洲视频 | 日韩精品一区二区不卡 | 欧美激情视频久久 | 精品99久久 | 制服丝袜亚洲 | 日韩一区二区三区高清免费看看 | www久久| 久久美女电影 | 成人国产精品一区 | 久久视频网址 | 国色天香永久免费 | 国产91小视频 | 国产成人精品一区二区在线 | 国产在线观看你懂得 | 99精品视频在线观看播放 | 在线免费看黄网站 | 天天天干夜夜夜操 | 日韩精品一区电影 | 又黄又刺激的视频 | 国产精品系列在线观看 | 中文av字幕在线观看 | 久久精品79国产精品 | 久久久久www | 色国产在线 | 天天操夜| 国产96在线| 欧美福利片在线观看 | 欧美日韩中文视频 | 日韩高清不卡一区二区三区 | 国产精品久久久久一区二区三区共 | 国产无套精品久久久久久 | 国产一级片一区二区三区 | 中国美女一级看片 | 日本精品久久久久 | 最近更新中文字幕 | 在线涩涩| 国产精品黄色av | 亚洲精品女 | 亚洲黄色免费观看 | 超碰人人国产 | 一区二区三区在线观看 | 免费日韩一区二区三区 | 91精品国产乱码在线观看 | 香蕉影视 | 国产精品都在这里 | 在线日本看片免费人成视久网 | 99热这里只有精品久久 | 欧美日韩国产亚洲乱码字幕 | 国产91在| 国产不卡视频在线 | 久久嗨| 久久精品7 | 日本最新高清不卡中文字幕 | 99精品久久久久久久久久综合 | 九九综合久久 | 亚洲黄色成人 | 91色九色| 最近日本韩国中文字幕 | 亚洲久在线 | 免费亚洲视频 | 伊人伊成久久人综合网小说 | 亚洲高清视频在线播放 | 国语对白少妇爽91 | 成人av网站在线观看 | 91视频最新网址 | 天天插天天干 | 狠狠躁天天躁 | 日韩视频在线不卡 | 久久久国内精品 | 日韩有码第一页 | 久草观看 | 91亚洲精品久久久中文字幕 | 91香蕉视频污在线 | 亚洲国产经典视频 | 美女国内精品自产拍在线播放 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 欧美日韩高清一区 | 国产在线a免费观看 | 免费毛片一区二区三区久久久 | 91热精品| 国产美腿白丝袜足在线av | 久久国产精品免费一区二区三区 | 天天爱天天射天天干天天 | 久久久久www | 日韩中文字幕视频在线观看 | 国产精品爽爽久久久久久蜜臀 | 日韩精品一卡 | 91成人天堂久久成人 | 波多野结衣资源 | 中国美女一级看片 | 久久首页 | 人人网av| 99九九视频 | 亚洲,国产成人av | 麻豆观看| 亚洲一区二区三区在线看 | 亚洲一二三久久 | 深爱婷婷激情 | 五月天亚洲综合小说网 | 色综合久久中文字幕综合网 | 在线免费看黄色 | 国产精品系列在线 | 天天干夜夜爱 | 国产精品网址在线观看 | 夜色资源站wwwcom | 伊人永久在线 | 麻花豆传媒mv在线观看网站 | 欧美精选一区二区三区 | 最近高清中文在线字幕在线观看 | 国产在线精品播放 | 欧美一级性视频 | 欧美一区二区在线刺激视频 | 国产精品porn | 天天躁天天操 | 国产99久久久国产 | 国产成人久久精品77777综合 | 一区免费视频 | 色久综合| 亚洲人精品午夜 | 日韩av成人 | 国产精品色婷婷 | 久久久久综合视频 | 日韩欧美一区二区三区视频 | 国产精品免费观看国产网曝瓜 | 91大神视频网站 | 亚洲综合激情小说 | 亚洲激情六月 | 欧美极品少妇xxxx | 国产女v资源在线观看 | 国产原创av在线 | 最新av在线网站 | 在线视频18在线视频4k | 国产黄色片在线 | 欧美亚洲一区二区在线 | 超碰公开在线观看 | 一级黄色视屏 | av在线观| 黄色在线成人 | 在线观看你懂的网址 | 欧美在线观看视频免费 | 久久天堂亚洲 | aaa黄色毛片| 久久麻豆精品 | 99免费在线视频观看 | 国产精品毛片一区二区 | 一区二区三区四区在线免费观看 | 日韩免费一二三区 | 人成免费网站 | 婷婷免费在线视频 | 在线免费看黄色 | 成人小电影在线看 | 日韩免费电影一区二区 | 欧美天堂久久 | a黄色| 日本精品视频在线 | 免费色网站| av在线网站观看 | 黄污污网站| 国产一区在线观看免费 | 日韩精品一区电影 | 婷婷视频在线播放 | 日韩有码中文字幕在线 | 亚洲精品玖玖玖av在线看 | 久草爱 | 人人擦| 6080yy午夜一二三区久久 | av福利第一导航 | 午夜av色 | 91福利国产在线观看 | 欧美日韩中文另类 | 99热这里只有精品国产首页 | 99久久精品一区二区成人 | 日本黄色大片免费看 | 亚洲综合爱 | 91精品1区2区 | 日韩精品中文字幕在线播放 | 国产一级在线观看视频 | 国产色在线 | 91av在线精品 | 99re国产视频 | 成人午夜性影院 | 日韩理论在线 | 国产精品麻豆99久久久久久 | 精品久久1| 日韩av有码在线 | 99久久夜色精品国产亚洲 | 嫩嫩影院理论片 | 在线日本看片免费人成视久网 | 欧美一区二区伦理片 | 亚洲精品色视频 | 日本高清免费中文字幕 | 探花视频在线观看 | 久 久久影院 | 亚洲国产精品电影 | 激情av资源网 | 国产精品免费视频一区二区 | 免费观看日韩 | 成人久久精品视频 | 视频1区2区 | 欧美精品乱码久久久久久 | 久久久精品高清 | 最近2019好看的中文字幕免费 | 四虎成人精品在永久免费 | 五月丁香| 免费观看成人网 | 日韩在线在线 | 天天伊人狠狠 | 97视频免费在线观看 | 午夜精品久久久久99热app | 久 久久影院 | 免费观看版 | 97在线观看免费视频 | 人成电影网 | 99热精品国产一区二区在线观看 | 欧美日韩中 | 亚洲伊人色| www.亚洲在线| 中文字幕影片免费在线观看 | 黄色免费在线看 | 日韩欧美高清一区二区三区 | 五月婷在线视频 | 午夜久久网 | 国产专区在线 | 国产一区二区三区高清播放 | 91精品视频观看 | 天天色天天干天天色 | 成 人 黄 色 片 在线播放 | 探花视频免费在线观看 | 日韩欧美视频免费在线观看 | 高潮久久久久久久久 | 91大神dom调教在线观看 | 国产在线资源 | 欧美日韩在线观看一区 | 亚洲欧美成人网 | 天天曰天天爽 | 国产精品久久久久久久av电影 | 黄色午夜网站 | 色视频成人在线观看免 | 三级黄色网络 | 亚洲欧美视频在线播放 | 午夜精品久久一牛影视 | 在线精品在线 | 18国产精品福利片久久婷 | 久久久久国产精品免费免费搜索 | 国内精品久久久 | 91九色蝌蚪国产 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 免费能看的黄色片 | 国产精品美女久久久网av | 日韩成人免费在线电影 | 国产h片在线观看 | 亚洲欧美日韩精品久久奇米一区 | 天天干天天干天天操 | 成人h在线 | 91探花国产综合在线精品 | 精品国产一区二区三区久久久 | 国产在线一区二区三区播放 | www狠狠| 久久99精品久久久久久久久久久久 | 国产中文欧美日韩在线 | 黄色一集片 | 福利久久久 | 欧美色久| 成人试看120秒 | 成人免费观看大片 | 国产精品涩涩屋www在线观看 | 黄在线| 久久久久国产精品午夜一区 | 黄色在线网站噜噜噜 | 久久免费视频在线观看6 | 日本中文一级片 | 久草视频在线免费看 | 中文字幕资源在线 | 亚洲国内精品在线 | www狠狠操 | 人人爱人人做人人爽 | 日韩精品亚洲专区在线观看 | 99精品在这里 | 久久久高清一区二区三区 | 五月天精品视频 | 亚洲动漫在线观看 | 精品一区二区三区香蕉蜜桃 | 国产片免费在线观看视频 | 亚洲伦理中文字幕 | 亚洲无在线 | 国产三级av在线 | 日韩mv欧美mv国产精品 | 午夜精品一区二区三区视频免费看 | 啪嗒啪嗒免费观看完整版 | 国产视频久久久久 | 国产在线观看国语版免费 | 香蕉在线视频播放网站 | 免费看黄在线观看 | 国产99久久99热这里精品5 | 国产在线精品福利 | 久久神马影院 | 97香蕉超级碰碰久久免费软件 | 青草草在线视频 | 综合网五月天 | 高清不卡一区二区在线 | 免费在线观看亚洲视频 | 欧美 日韩 国产 成人 在线 | 狠狠干网站 | 91精品啪在线观看国产 | 99久久精品久久亚洲精品 | 91精品视频在线 | 黄色午夜| 日韩在线免费 | 日韩高清dvd | 在线免费观看av网站 | 国产乱对白刺激视频在线观看女王 | 久久人人爽爽人人爽人人片av | a黄色一级 | 黄色免费网战 | av在线网站免费观看 | 久久视频免费在线 | 成人性生爱a∨ | 国产免费小视频 | 手机av在线免费观看 | 狠狠干天天操 | 欧美视频99 | av免费看网站 | 午夜久久影视 | 国产午夜精品福利视频 | 免费看十八岁美女 | 欧美国产三区 | 在线观看日本韩国电影 | 91免费高清 | 国产99久久久国产精品成人免费 | 日韩在线高清 | 成人国产电影在线观看 | 国产精品美女久久久久久久久久久 | 激情av在线播放 | 国产精品亚洲精品 | 久久久国产精品电影 | 黄色精品久久 | 一区二区视频在线播放 | 久久精品波多野结衣 | 超碰97免费 | 91人人揉日日捏人人看 | 亚洲最大免费成人网 | 国产精品 国产精品 | 天天干亚洲 | 99热这里有精品 | 91色综合| 免费激情在线电影 | 亚洲国产美女精品久久久久∴ | 午夜国产福利在线 | 手机成人av在线 | 九九久久久久久久久激情 | 玖玖视频精品 | 精品国产亚洲日本 | 欧美日韩中文在线观看 | 中文av网| 久久久久国产a免费观看rela | 成人久久免费视频 | 菠萝菠萝在线精品视频 | 国产清纯在线 | 99在线观看免费视频精品观看 | 国产精品午夜久久久久久99热 | 久久超碰网 | 91精品国产网站 | 456成人精品影院 | 狠狠狠色丁香婷婷综合久久88 | 国产精品h在线观看 | 久久久资源| 久久精精品视频 | 一区二区免费不卡在线 | 91香蕉国产 | 成人久久18免费网站麻豆 | 日韩欧美在线综合网 | 在线观看免费高清视频大全追剧 | 国产精品成人免费 | 久久久91精品国产一区二区三区 | 久久成人资源 | 久久国产经典视频 | 国产精品18久久久久久首页狼 | 国产亚洲精品久久久久久电影 | 涩五月婷婷 | 久草在线一免费新视频 | 国模一区二区三区四区 | 人人爱爱人人 | 玖玖视频免费在线 | 免费看国产黄色 | 国产综合久久 | 国产视频中文字幕在线观看 | 亚洲高清视频一区二区三区 | 福利二区视频 | 夜夜骑首页 | 一级免费黄视频 | 伊人小视频 | 免费一级片在线观看 | 日韩草比| 不卡在线一区 | 天天摸天天舔天天操 | 亚洲精品视频网址 | 又黄又爽又湿又无遮挡的在线视频 | 91福利试看| 色94色欧美 | 欧美超碰在线 | 综合铜03| 一区二三国产 | 狠狠干婷婷色 | 丁香六月婷婷开心 | 91九色蝌蚪国产 | 免费国产黄线在线观看视频 | 亚洲视频免费在线 | 天天看天天干天天操 | 色综合色综合色综合 | 国产日韩精品在线 | 国产精品系列在线 | 亚洲精品中文在线资源 | 亚洲国产精品传媒在线观看 | 成人动漫一区二区三区 | 国产精品一区二区三区99 | 在线观看免费色 | 天天插综合网 | 又色又爽又黄高潮的免费视频 | 五月天天色 |