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

前端: 如何讓你的Table組件無限可能

開發(fā) 前端
在管理后臺(tái)中我們會(huì)使用大量的表格表單組件, 導(dǎo)入導(dǎo)出各種報(bào)表, 有些場(chǎng)景還需要對(duì)報(bào)表數(shù)據(jù)進(jìn)行可視化分析, 動(dòng)態(tài)生成可視化圖表, 筆者將基于以上場(chǎng)景, 總結(jié)一些實(shí)用的 Table 組件開發(fā)技巧, 讓前端開發(fā)不再吃力.

[[377957]]

 在管理后臺(tái)中我們會(huì)使用大量的表格表單組件, 導(dǎo)入導(dǎo)出各種報(bào)表, 有些場(chǎng)景還需要對(duì)報(bào)表數(shù)據(jù)進(jìn)行可視化分析, 動(dòng)態(tài)生成可視化圖表, 筆者將基于以上場(chǎng)景, 總結(jié)一些實(shí)用的 Table 組件開發(fā)技巧, 讓前端開發(fā)不再吃力.

往期經(jīng)典

  • 輕松教你搞定組件的拖拽, 縮放, 多控制點(diǎn)伸縮和拖拽數(shù)據(jù)上報(bào)
  • 基于自然流布局的可視化拖拽搭建平臺(tái)設(shè)計(jì)方案
  • 基于React+Koa實(shí)現(xiàn)一個(gè)h5頁面可視化編輯器-H5-Dooring

效果演示


技術(shù)點(diǎn)

  • 實(shí)現(xiàn) Table 動(dòng)態(tài)渲染
  • Table 排序, 多列排序, 自定義搜索
  • 批量導(dǎo)入 Excel 數(shù)據(jù)渲染 Table
  • 將 Table 數(shù)據(jù)導(dǎo)出為 Excel 文件
  • 基于 Table 數(shù)據(jù)自動(dòng)生成多維度可視化報(bào)表
  • 實(shí)現(xiàn)簡(jiǎn)單的 Table 編輯器

以上是幾個(gè)常用的業(yè)務(wù)分場(chǎng)景, 接下來筆者帶大家一一實(shí)現(xiàn).

技術(shù)實(shí)現(xiàn)

1. 實(shí)現(xiàn) Table 動(dòng)態(tài)渲染

一般我們渲染表格, 大多數(shù)是預(yù)先將表格結(jié)構(gòu)寫好, 比先定義好columns再向后端請(qǐng)求數(shù)據(jù)填充表格, 如下:

  1. const columns = [ 
  2.   { 
  3.     title: '姓名'
  4.     dataIndex: 'name'
  5.     key'name'
  6.   }, 
  7.   { 
  8.     title: '年齡'
  9.     dataIndex: 'age'
  10.     key'age'
  11.   }, 
  12.   { 
  13.     title: '住址'
  14.     dataIndex: 'address'
  15.     key'address'
  16.   }, 
  17. ]; 
  18. const dataSource = [ 
  19.   { 
  20.     key'1'
  21.     name'徐小夕'
  22.     age: 18, 
  23.     address: '杭州夕湖區(qū)'
  24.   } 
  25. ]; 
  26.  
  27. <Table dataSource={dataSource} columns={columns} /> 

 這種業(yè)務(wù)場(chǎng)景雖然可以滿足大部分后臺(tái)管理系統(tǒng)的Table需求, 也可以使用 antd 或者 element 構(gòu)建, 但是對(duì)于 lowcode 系統(tǒng)而言, 很多模塊都是不確定的, 我們需要根據(jù)協(xié)議數(shù)據(jù)來驅(qū)動(dòng) Table 的渲染.

比如我們?cè)?strong> H5-Dooring 中配置了一個(gè)表單, 我們要統(tǒng)計(jì)分析表單的數(shù)據(jù), 由于表單項(xiàng)是不確定的, 所以我們無法提前定義好一個(gè) table schema.


那如何來動(dòng)態(tài)渲染這個(gè) Table 呢? 這里給大家提供一個(gè)思路, 基于數(shù)據(jù)驅(qū)動(dòng) + 協(xié)議層約束. 類似于國(guó)外 SAP 的 低代碼平臺(tái), 完全基于 odata 協(xié)議, 我們可以約束表單的提交數(shù)據(jù)格式, 然后結(jié)合用戶提交的數(shù)據(jù), 動(dòng)態(tài)提取出 Table 所需的 columns, 最后再渲染 Table 組件.


協(xié)議層主要約束不同字段的展示類型, 比如字符串, 按鈕, 鏈接, 標(biāo)簽等, 用戶在提交表單之后會(huì)攜帶協(xié)議層對(duì)應(yīng)的 flag 和用戶輸入的值, 這有利于我們解析器渲染Table時(shí)可以對(duì)不同的列展示不同的類型. 如下:


筆者這里簡(jiǎn)單實(shí)現(xiàn)一個(gè)demo, 如下:

  1. // table數(shù)據(jù)源 
  2. let tableData = res.map((item:any,i:number) => ({ ID: nanoid(8), ...item })); 
  3. let baseRow = tableData[0], 
  4. keys = Object.keys(baseRow); 
  5. setColumns(() => { 
  6.   const baseColumn = keys.map(item => { 
  7.     return { 
  8.       title: item, 
  9.       dataIndex: item, 
  10.       key: item, 
  11.       width: item === 'ID' ? 0 : null
  12.       render: (v:any) => { 
  13.         if(typeof v === 'object') { 
  14.           return <> 
  15.             { 
  16.               v.map(item => <Tag color="#2F54EB">{ item.label || item }</Tag>) 
  17.             } 
  18.           </> 
  19.         } 
  20.         return item === 'ID' ? '' : v 
  21.       } 
  22.     } 
  23.   }) 
  24.   baseColumn.push({ 
  25.     title: '操作'
  26.     key'operation'
  27.     fixed: 'right'
  28.     width: 100, 
  29.     render: (row) => <a onClick={() => handleDel(row)}>刪除</a>, 
  30.   }) 
  31.   return baseColumn 
  32. }) 

以上我們就實(shí)現(xiàn)了一個(gè)動(dòng)態(tài) Table 渲染方案, 案例中使用了 react, 大家也可以使用熟悉的 vue3.0.

2. Table 排序, 多列排序, 自定義搜索

Table 排序, 多列排序?qū)崿F(xiàn)方式也很簡(jiǎn)單, 我們只需要自定義 Table 頭部, 對(duì)排序字段提升為 Table 的公共 State, 最后通過排序標(biāo)識(shí)和排序方法進(jìn)行排序即可. 目前 antd4.0已經(jīng)支持多列排序, 大家可以直接參考學(xué)習(xí)即可, 如下:

 

對(duì)于自定義搜索, 也就是文章開頭的 demo 展示的列搜索, 我們可以采用如下方案實(shí)現(xiàn):

  1. const getColumnSearchProps = dataIndex => ({ 
  2.   filterDropdown: ({ setSelectedKeys, selectedKeys, confirm, clearFilters }) => ( 
  3.     <div style={{ padding: 8 }}> 
  4.       <Input 
  5.         ref={node => { 
  6.           searchInput = node; 
  7.         }} 
  8.         placeholder={`Search ${dataIndex}`} 
  9.         value={selectedKeys[0]} 
  10.         onChange={e => setSelectedKeys(e.target.value ? [e.target.value] : [])} 
  11.         onPressEnter={() => handleSearch(selectedKeys, confirm, dataIndex)} 
  12.         style={{ width: 188, marginBottom: 8, display: 'block' }} 
  13.       /> 
  14.       <Space
  15.         <Button 
  16.           type="primary" 
  17.           onClick={() => handleSearch(selectedKeys, confirm, dataIndex)} 
  18.           icon={<SearchOutlined />} 
  19.           size="small" 
  20.           style={{ width: 90 }} 
  21.         > 
  22.           搜索 
  23.         </Button> 
  24.         <Button onClick={() => handleReset(clearFilters)} size="small" style={{ width: 90 }}> 
  25.           重置 
  26.         </Button> 
  27.       </Space
  28.     </div> 
  29.   ), 
  30.   filterIcon: filtered => <SearchOutlined style={{ color: filtered ? '#1890ff' : undefined }} />, 
  31.   onFilter: (value, record) => 
  32.     record[dataIndex] 
  33.       ? record[dataIndex].toString().toLowerCase().includes(value.toLowerCase()) 
  34.       : ''
  35.   onFilterDropdownVisibleChange: visible => { 
  36.     if (visible) { 
  37.       setTimeout(() => searchInput.select(), 100); 
  38.     } 
  39.   }, 
  40.   render: text => 
  41.     searchedColumn === dataIndex ? ( 
  42.       <Highlighter 
  43.         highlightStyle={{ backgroundColor: '#ffc069', padding: 0 }} 
  44.         searchWords={[searchText]} 
  45.         autoEscape 
  46.         textToHighlight={text ? text.toString() : ''
  47.       /> 
  48.     ) : ( 
  49.       text 
  50.     ), 
  51. }); 

 此時(shí)我們只需要對(duì)動(dòng)態(tài)生成的columns每一列添加自定義頭部即可:

  1.   title: item, 
  2.   dataIndex: item, 
  3.   key: item, 
  4.   ...getColumnSearchProps(item) 

antd4.0 中也有詳細(xì)的使用方式, 這里筆者就不一一介紹了, 效果如下:


大家也可以在 H5-Dooring 的管理后臺(tái)中查看具體效果.

3. 批量導(dǎo)入 Excel 數(shù)據(jù)渲染 Table

在很多數(shù)據(jù)分析后臺(tái)中我們需要處理很多電子表格, 用傳統(tǒng)的excel手動(dòng)錄入的方式將慢慢被淘汰. 比如不同渠道方收集到了很多業(yè)務(wù)數(shù)據(jù), 整理到 excel 中, 那如何快速保存到自己的后臺(tái)系統(tǒng)中呢? 一般的思路如下:

  • 通過表單的方式一條條錄入
  • 后臺(tái)解析文件處理成規(guī)范的可入庫(kù)數(shù)據(jù)結(jié)構(gòu)
  • 前端實(shí)現(xiàn)一件導(dǎo)入 excel, 自動(dòng)同步數(shù)據(jù)

第一種方案由于效率太低, 適合C端用戶手動(dòng)錄入, 我們暫時(shí)忽略, 筆者將實(shí)現(xiàn)一下第三種方案. 實(shí)現(xiàn)思路如下:


這里我們用到了 XLSX 這個(gè)庫(kù), 結(jié)合 FileReader API. 我們通過FileReader 拿到excel文件的二進(jìn)制數(shù)據(jù), 然后傳給 XLSX 解析成 js object, 最后通過筆者寫的 table 渲染器生成符合規(guī)范的table數(shù)據(jù)結(jié)構(gòu). 源碼如下:

  1. // 解析并提取excel數(shù)據(jù) 
  2. let reader = new FileReader(); 
  3. reader.onload = function(e) { 
  4.   let data = e.target.result; 
  5.   let workbook = XLSX.read(data, {type: 'binary'}); 
  6.   let sheetNames = workbook.SheetNames; // 工作表名稱集合 
  7.   let draftArr = {} 
  8.   sheetNames.forEach(name => { 
  9.     let worksheet = workbook.Sheets[name]; // 只能通過工作表名稱來獲取指定工作表 
  10.     for(let key in worksheet) { 
  11.       // v是讀取單元格的原始值 
  12.       if(key[0] !== '!') { 
  13.         if(draftArr[key[0]]) { 
  14.           draftArr[key[0]].push(worksheet[key].v) 
  15.         }else { 
  16.           draftArr[key[0]] = [worksheet[key].v] 
  17.         } 
  18.       } 
  19.     } 
  20.   }); 
  21.   // 得到table合法的數(shù)據(jù)產(chǎn)物 
  22.   const sourceData = Object.values(draftArr); 
  23. reader.readAsBinaryString(file); 

拿到合法的table 數(shù)據(jù)源之后我們就可以進(jìn)行第一節(jié)說的動(dòng)態(tài)渲染 Table 的邏輯了.

通過以上的方式, 我們可以實(shí)現(xiàn)任何結(jié)構(gòu)的excel表格的導(dǎo)入. 在導(dǎo)入后我們可以自動(dòng)發(fā)送請(qǐng)求存儲(chǔ)到我們的業(yè)務(wù)后臺(tái)中.

4. 將 Table 數(shù)據(jù)導(dǎo)出為 Excel

類似的, 上面我們介紹了將 excel 導(dǎo)入 table, 同樣我們也可以將Table 導(dǎo)出為 excel, 進(jìn)行數(shù)據(jù)的分發(fā), 本地化, 比如我們最近流行的在線文檔等應(yīng)用. 筆者這里簡(jiǎn)單講一下實(shí)現(xiàn)思路:


也就是我們第3節(jié)說的反解析. excel 文件生成筆者采用 js-export-excel 這個(gè)庫(kù), 基于它筆者實(shí)現(xiàn)了一個(gè)開箱即用的方法, 避免大家燒腦造輪子. 如下:

  1. import ExportJsonExcel from 'js-export-excel'
  2.  
  3. const generateExcel = () => { 
  4.     let option:any = {};  //option代表的就是excel文件 
  5.     let dataTable = [];  //excel文件中的數(shù)據(jù)內(nèi)容 
  6.     let len = list.length; 
  7.     if (len) { 
  8.         for(let i=0; i<len; i++) { 
  9.             let row = list[i]; 
  10.             let obj:any = {}; 
  11.             for(let key in row) { 
  12.                 if(typeof row[key] === 'object') { 
  13.                     let arr:any = row[key]; 
  14.                     obj[key] = arr.map((item:any) => (typeof item === 'object' ? item.label : item)).join(','
  15.                 }else { 
  16.                     obj[key] = row[key
  17.                 } 
  18.             } 
  19.             dataTable.push(obj);  //設(shè)置excel中每列所獲取的數(shù)據(jù)源 
  20.         } 
  21.     } 
  22.     let tableKeys = Object.keys(dataTable[0]); 
  23.     option.fileName = tableName;  //excel文件名稱 
  24.     option.datas = [ 
  25.           { 
  26.             sheetData: dataTable,  //excel文件中的數(shù)據(jù)源 
  27.             sheetName: tableName,  //excel文件中sheet頁名稱 
  28.             sheetFilter: tableKeys,  //excel文件中需顯示的列數(shù)據(jù) 
  29.             sheetHeader: tableKeys,  //excel文件中每列的表頭名稱 
  30.           } 
  31.     ] 
  32.     let toExcel = new ExportJsonExcel(option);  //生成excel文件 
  33.     toExcel.saveExcel();  //下載excel文件 

5. 基于 Table 數(shù)據(jù)自動(dòng)生成多維度可視化報(bào)表

在后臺(tái)管理系統(tǒng)和 BI 平臺(tái)中我們會(huì)遇到很多數(shù)據(jù)分析和報(bào)表展示的需求, 接下來筆者將來介紹一下如何基于 Table 數(shù)據(jù)動(dòng)態(tài)生成多維度可視化分析報(bào)表.

筆者在之前的文章中介紹過 度量行這個(gè)概念, 對(duì)于數(shù)據(jù)分析而言, 我們也要考慮可分析維度的概念, 比如什么是可分析的, 什么是不可分析的. 比如我們又一個(gè)表格, 里面有如下結(jié)構(gòu):


對(duì)于聯(lián)系方式而言, 它是不可度量的, 即分析該項(xiàng)指沒有任何價(jià)值, 所以在自動(dòng)生成多維度分析中我們理論上不因該分析它, 基于這個(gè)原理, 我們來設(shè)計(jì)一個(gè)簡(jiǎn)單的自動(dòng)生成多維度可視化報(bào)表的方案.

5.1 基于數(shù)據(jù)源獲取維度數(shù)據(jù)

我們針對(duì)具有范圍屬性的維度進(jìn)行度量, 生成度量數(shù)據(jù), 代碼如下:

  1. const generateDistData = (key:string, list:any) => { 
  2.     let distDataMap:any = {}, 
  3.         distData = [] 
  4.     list.forEach((item:any) => { 
  5.         // 當(dāng)前緯度的類別 
  6.         let curKey = typeof item[key] === 'object' ? item[key][0].label : item[key]; 
  7.         if(distDataMap[curKey]) { 
  8.             distDataMap[curKey]++; 
  9.         }else { 
  10.             distDataMap[curKey] = 1; 
  11.         } 
  12.     }) 
  13.  
  14.     // 生成目標(biāo)數(shù)組 
  15.     for(let key in distDataMap) { 
  16.         distData.push({namekey, value: distDataMap[key]}) 
  17.     } 
  18.     return distData 
  19.   } 

此時(shí)我們只需要根據(jù)維度的字段, 即可獲取某一維度的數(shù)據(jù)值, 后通過可視化組件渲染即可.

5.2 基于某一維度生成可視化報(bào)表

我們用@ant-design/charts, 代碼如下:

  1. <div className={styles.anazlyHeader}> 
  2.     <div className={styles.anazlyItem}> 
  3.         <span>分析緯度: </span> 
  4.         <Select style={{ width: 120 }} onChange={(v) => handleAnazlyChange(0, v)} defaultValue={keys[0]}> 
  5.             { 
  6.                 keys.map((item,i) => { 
  7.                     return <Option value={item} key={i}>{ item }</Option
  8.                 }) 
  9.             } 
  10.         </Select
  11.     </div> 
  12. </div> 
  13. <div className={styles.anazlyContent}> 
  14.     { 
  15.         !!config && <Pie {...config} /> 
  16.     } 
  17. </div> 
實(shí)現(xiàn)效果如下:
圖片

6. 實(shí)現(xiàn)簡(jiǎn)單的 Table 編輯器

實(shí)現(xiàn) Table 編輯器其實(shí)筆者在 前端如何一鍵生成多維度數(shù)據(jù)可視化分析報(bào)表 已經(jīng)詳細(xì)分析過了,也集成在了H5-Dooring 的可視化組件編輯器中, 具體 demo 如下:


大家感興趣可以研究一下.

最后

目前筆者也在持續(xù)更新H5編輯器 H5-Dooring, 最近來同步一下功能:

  • 修復(fù)圖片庫(kù)選擇bug
  • 添加省市級(jí)聯(lián)組件
  • 添加批量導(dǎo)入 excel 數(shù)據(jù)的能力
  • 添加表單自定義校驗(yàn)
  • 音頻組件添加自動(dòng)播放控制, 循環(huán)播放等配置項(xiàng)
  • 添加橫向滑動(dòng)組件

 

責(zé)任編輯:姜華 來源: 趣談前端
相關(guān)推薦

2016-09-21 09:16:55

Qlik

2009-06-11 11:39:33

無線網(wǎng)絡(luò)定位

2023-10-27 14:25:26

組件庫(kù)無限可能性

2024-05-20 00:00:00

2015-09-09 18:06:53

戴爾云計(jì)算

2024-11-01 10:34:45

2025-06-20 08:14:55

2017-09-07 12:54:59

華為云計(jì)算HC大會(huì)

2024-01-10 08:14:10

Java反射工具

2013-07-12 13:24:19

App誘惑

2018-03-30 10:02:08

代碼規(guī)范維護(hù)工程師

2015-05-21 08:53:21

華為HNC/華為

2012-06-26 10:33:17

2017-07-14 09:06:10

存儲(chǔ)數(shù)據(jù)中心HCI

2012-09-21 10:04:03

寬帶華為

2012-07-10 13:57:19

Web前端

2015-12-25 09:51:13

售前工程師圣誕成長(zhǎng)

2023-08-31 22:24:18

Vega擴(kuò)散模型圖像

2018-07-31 10:04:22

京東云教育

2025-08-27 01:41:00

點(diǎn)贊
收藏

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

岛国大片在线免费观看| 区一区二区三区中文字幕| 日韩成人毛片视频| 久久男人av| 91激情五月电影| 欧美日韩精品免费观看| 一女二男一黄一片| 在线视频精品| xxav国产精品美女主播| 国内av一区二区| 白浆视频在线观看| 中文字幕电影一区| 国产日韩欧美二区| 亚洲无码精品国产| 一本色道久久综合亚洲精品高清| 最好看的2019年中文视频 | 永久免费观看片现看| 精品国产鲁一鲁****| 色狠狠一区二区| 9191国产视频| yes4444视频在线观看| 成人午夜激情在线| 成人网在线观看| 久久国产精品免费看| 99视频精品全国免费| 亚洲男人天堂九九视频| 永久看看免费大片| 激情欧美一区二区三区黑长吊| 婷婷综合在线观看| 久久av喷吹av高潮av| 久久免费看视频| 成人app下载| 91在线精品视频| 最好看的日本字幕mv视频大全 | 久久久噜噜噜www成人网| 国产午夜精品久久久久免费视| 久久久综合视频| 国产精品v欧美精品v日韩精品| 亚洲无码精品在线观看| 日韩av中文在线观看| 98精品国产自产在线观看| 99自拍视频在线| 成人网18免费网站| 亚洲天堂av在线免费观看| 星空大象在线观看免费播放| 视频免费一区二区| 欧美一区二区三区的| 日韩一级理论片| 久久r热视频| 精品国产精品自拍| 日本丰满少妇xxxx| 蜜桃视频在线观看免费视频| 亚洲高清三级视频| 青青草国产免费| 国产精品探花在线| 亚洲制服丝袜在线| 国产精品va在线观看无码| 亚洲91av| 一区二区三区成人| 久草视频国产在线| аⅴ资源天堂资源库在线| 亚洲国产日韩a在线播放| 欧美国产视频一区| 丁香花在线高清完整版视频| 亚洲成在线观看| 国产午夜大地久久| 国产伦精品一区二区三区视频金莲| 欧美日韩国产区| 日韩人妻精品无码一区二区三区| 成人小电影网站| 欧洲国内综合视频| 一女二男3p波多野结衣| 国产欧美88| 精品毛片乱码1区2区3区| 国产人妻黑人一区二区三区| 色先锋久久影院av| 中文字幕成人在线| 天天操天天操天天操天天操天天操| 亚洲国产老妈| 久久久综合av| 91精品国产高清一区二区三密臀| 久色成人在线| 91视频免费在线| 丰满人妻一区二区三区免费| 成人av在线网| 欧美中文娱乐网| 欧美午夜电影一区二区三区| 亚洲婷婷综合色高清在线| av片在线免费| 粉嫩一区二区| 欧美一区二区三区四区高清| 日韩精品人妻中文字幕有码| 欧美女优在线视频| 久久成人一区二区| 韩国av中文字幕| 久久午夜精品| 91九色蝌蚪成人| 美女毛片在线看| 亚洲男人电影天堂| 妺妺窝人体色www在线小说| 婷婷久久综合九色综合99蜜桃| 亚洲第一福利在线观看| 亚洲精品国产熟女久久久| 欧美hd在线| 91成人在线播放| 中日韩av在线| 成人一区二区三区| 亚洲欧洲一区二区| 不卡的av影片| 9191国产精品| 亚洲人成人无码网www国产| 亚洲一区 二区 三区| 日韩免费高清在线观看| 亚洲第一页视频| 中文字幕av不卡| 91免费黄视频| 精品视频在线观看免费观看| 亚洲午夜精品久久久久久久久久久久| 欧美色图一区二区| 美女在线观看视频一区二区| 精品免费国产| 欧美videossex另类| 欧美日韩亚洲另类| 亚洲熟妇无码av| 伊人久久大香线蕉av超碰演员| 国产欧亚日韩视频| 国内在线精品| 精品久久久免费| 性猛交╳xxx乱大交| 98精品视频| 国产精品久久久久久久久久新婚| 天天色综合av| 亚洲资源在线观看| 性一交一黄一片| 小处雏高清一区二区三区| 国产精品a久久久久久| 天堂中文在线看| 亚洲国产另类精品专区| 中文字幕第六页| 亚洲午夜精品一区 二区 三区| 国产在线观看精品| 日本www在线观看| 在线一区二区观看| 成人免费看aa片| 日韩视频二区| 国产一区二区高清视频| 久久免费电影| 精品国产欧美一区二区| 澳门黄色一级片| 国产精一区二区三区| 国产精品美女在线播放| 99精品美女视频在线观看热舞| 中文字幕一精品亚洲无线一区 | 特级西西人体高清大胆| 日本不卡123| 亚洲欧美日本国产有色| 日韩黄色碟片| 久久午夜a级毛片| 99在线精品视频免费观看软件| 中文字幕一区在线观看| 亚洲自拍第三页| 欧美色图麻豆| 久久本道综合色狠狠五月| 一本大道色婷婷在线| 亚洲精品色婷婷福利天堂| 无码人妻一区二区三区免费| 国产人成亚洲第一网站在线播放| 亚洲黄色小视频在线观看| 久久中文字幕av| 91偷拍精品一区二区三区| 国产www视频在线观看| 日韩激情片免费| 中文字幕精品无| 国产精品电影院| 人妻巨大乳一二三区| 亚洲青色在线| 欧美性大战久久久久| 丁香久久综合| 欧美激情手机在线视频| 亚洲aaa在线观看| 欧美在线啊v一区| 欧美一级片在线视频| 成人久久18免费网站麻豆 | 久久久久成人片免费观看蜜芽| 成人av综合一区| 99热手机在线| 欧美极品一区二区三区| 久久久久久亚洲精品不卡4k岛国| 日本精品在线一区| 欧美日韩不卡合集视频| 暖暖视频在线免费观看| 这里是久久伊人| 久久久久久久久影院| 国产精品亲子伦对白| 亚洲一级Av无码毛片久久精品| 视频在线观看国产精品| 国产香蕉一区二区三区| 一区三区在线欧| 亚洲a中文字幕| 精品国产免费人成网站| 欧美高跟鞋交xxxxhd| 国产高清在线看| 精品国内片67194| 波多野结衣黄色| 亚洲一级二级三级在线免费观看| 亚洲ⅴ国产v天堂a无码二区| 国产成人av自拍| 久久久精品麻豆| 亚洲欧洲午夜| 永久免费在线看片视频| 免费看成人哺乳视频网站| 91精品黄色| 青娱乐极品盛宴一区二区| 26uuu久久噜噜噜噜| 在线观看h网| 搡老女人一区二区三区视频tv| 色wwwwww| 欧美电影免费提供在线观看| 亚洲一区二区影视| 色婷婷国产精品| 国产黄色片视频| 亚洲精品欧美在线| 后入内射无码人妻一区| 久久久久9999亚洲精品| 国产婷婷在线观看| 国产精品亚洲成人| www.成年人| 日本不卡免费在线视频| 又色又爽又高潮免费视频国产| 亚洲经典视频在线观看| av日韩在线看| 欧美阿v一级看视频| 亚洲一区二区在线免费观看| 国产一区二区三区电影在线观看| 国产一区二区在线网站| 超碰一区二区三区| 97久久精品午夜一区二区| 91丨精品丨国产| 91精品免费久久久久久久久| av亚洲一区| 国产精品免费久久久久影院| 亚洲第一影院| 国产成人精品一区二区| 北岛玲heyzo一区二区| 51ⅴ精品国产91久久久久久| 亚洲黄色中文字幕| 欧美洲成人男女午夜视频| 天堂av在线网| 欧美整片在线观看| 综合另类专区| 国产成人亚洲综合青青| 欧美日韩在线精品一区二区三区激情综合 | 久久偷拍免费视频| 99久久夜色精品国产网站| 国产高清成人久久| 99精品视频在线观看免费| 亚洲精品乱码久久久久久不卡| 92精品国产成人观看免费| 91精品小视频| 26uuu亚洲综合色| 一区二区黄色片| 欧美激情在线免费观看| 成人欧美一区二区三区黑人一| 中文字幕制服丝袜一区二区三区| 亚洲精品久久久久久国| 亚洲综合激情另类小说区| 日韩手机在线观看| 日韩欧美国产网站| 高潮毛片又色又爽免费| 欧美日韩精品免费| 国产草草影院ccyycom| 欧美精品一区二区蜜臀亚洲| 天堂а在线中文在线无限看推荐| 亚洲毛片在线观看| 黄色免费在线网站| 最近2019中文字幕mv免费看| 欧美成人视屏| 欧美激情视频给我| 蜜桃av.网站在线观看| 国产精品成人一区二区| 国产精品视频一区视频二区| 国产精品视频福利| 久久99影视| 一本—道久久a久久精品蜜桃| 欧美+亚洲+精品+三区| 免费无码不卡视频在线观看| 日本欧美在线看| 中文字幕1区2区| 99re视频精品| 亚洲国产精品一区二区久久hs| 一区二区三区在线不卡| 中文在线第一页| 欧美日韩国产经典色站一区二区三区| 性网爆门事件集合av| 亚洲天天在线日亚洲洲精| av大全在线| 欧美与欧洲交xxxx免费观看| 日韩欧美三区| 精品国产乱码久久久久久郑州公司| 青草国产精品| 3d动漫一区二区三区| 激情深爱一区二区| 亚洲一区二区观看| 亚洲欧美色一区| 亚洲s码欧洲m码国产av| 精品国产a毛片| av在线二区| 992tv在线成人免费观看| 天天综合91| 欧美性xxxx69| 亚洲日本欧美| 日本r级电影在线观看| 久久久久久久久一| 国产精品a成v人在线播放| 欧美日韩一级二级三级| 色视频免费在线观看| 欧美乱大交xxxxx| 国产精品久久久久久久久久齐齐| 国产99视频精品免费视频36| 日韩av片子| 国产第一页视频| www.亚洲色图.com| 私库av在线播放| 欧美日韩美少妇| 国产永久免费高清在线观看| 81精品国产乱码久久久久久| 日韩一二三区| 最新欧美日韩亚洲| 欧美a一区二区| 波多野结衣av在线观看| 精品久久久久久中文字幕大豆网| 亚洲毛片在线播放| 另类色图亚洲色图| 亚洲综合资源| 亚洲欧美日韩精品在线| 久久人人精品| 女女互磨互喷水高潮les呻吟 | 亚洲欧美综合v| 欧美a级在线观看| 国严精品久久久久久亚洲影视| 国产主播一区| 免费观看一区二区三区| 亚洲免费高清视频在线| 国产色综合视频| 欧美乱妇40p| 伊人久久大香线蕉av超碰| 神马午夜伦理影院| 国产电影一区二区三区| 激情视频在线播放| 精品国产制服丝袜高跟| 福利在线导航136| 精品国产免费一区二区三区 | 国内久久久精品| 林ゆな中文字幕一区二区| 国模无码视频一区二区三区| 91蜜桃传媒精品久久久一区二区| 成人毛片在线播放| 国产一区二区三区免费视频| 国产电影一区二区三区爱妃记| 视频一区二区精品| 免费的成人av| 欧美精品久久久久久久久46p| 日韩欧美一级精品久久| 青春草在线免费视频| 国产精品一区二区三区精品| 一区二区三区精品视频在线观看 | 女人丝袜激情亚洲| 91福利国产成人精品播放| 亚洲欧洲成人自拍| 亚洲国产精品久久人人爱潘金莲 | 一区二区精品在线| 国产美女av一区二区三区| 久草中文在线视频| 亚洲精品永久免费精品| 99riav视频一区二区| 欧美aaa在线观看| 丁香婷婷深情五月亚洲| 欧美特黄aaaaaa| 久久九九国产精品怡红院| 亚洲精品午夜| 男人插女人下面免费视频| 亚洲人午夜精品天堂一二香蕉| 免费看黄色一级视频| 国产精品精品视频| 欧美成人tv| 精品少妇人妻一区二区黑料社区| 欧美日韩国产片| av影视在线| 一区二区不卡在线视频 午夜欧美不卡'| 国产精品18久久久| 亚洲欧美自拍视频| 久久精品国产亚洲精品2020| 日韩欧美ww| 欧美性猛交xxxx乱大交91| 天天av天天翘天天综合网 | 91中文字幕在线视频| 久久免费国产精品1| 欧美电影一区| 51调教丨国产调教视频| 欧美一区二区在线观看|