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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

React使用antd Table生成层级多选组件

發布時間:2025/3/8 编程问答 47 豆豆
生活随笔 收集整理的這篇文章主要介紹了 React使用antd Table生成层级多选组件 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、需求

  用戶對不同的應用需要有不同的權限,用戶一般和角色關聯在一起,新建角色的時候會選擇該角色對應的應用,然后對應用分配權限。于是寫了一種實現的方式。首先應用是一個二級樹,一級表示的是應用分組,二級表示的是應用,這是table的最左邊的數據。然后是按鈕的數據,這里顯示在table的頭部。

二、效果圖如下

  

?三、具體代碼

  1.RoleApplicationTable.js

import React from 'react'; import RoleCheckbox from 'components/role/RoleCheckbox'; import {Menu, Table, message} from 'antd'; import Btn from 'components/public/BaseBtn'; import {connect} from 'react-redux'; import 'styles/less/personType.less'; import 'styles/less/basebtn.less'; import Map from 'components/role/Map'; import { operationRoleAppBtn, queryRoleAppBtnData} from 'actions/role';var mapStateToProps = function(state){return {roleData: state.getRole } }; //規范屬性類型 var propTypes = {personTypes: React.PropTypes.object,dispatch : React.PropTypes.func }; class RoleApplicationTable extends React.Component {constructor(props) {super(props);this.state = {};this.chooseApp = this.chooseApp.bind(this);this.addColName = this.addColName.bind(this);this.addDataPid = this.addDataPid.bind(this);this.onChecked = this.onChecked.bind(this);this.addChildrenRow = this.addChildrenRow.bind(this);this.addData = this.addData.bind(this);this.isGroupRow = this.isGroupRow.bind(this);this.checkGroupAndColumnState = this.checkGroupAndColumnState.bind(this);//確保 組全選 和 列 全選this.cid = 0;this.rowNum = 0;this.colNum = 0;//mapthis.checkboxIdMapState= new Map();//checkboxId 映射 Statethis.parentRow = new Map();//每個checkboxId節點 對應最左邊的哪個應用this.parentCol = new Map();//每個checkboxId節點 對應最上邊的哪個按鈕this.childrenRow = new Map();//當前行的所有子行this.checkboxIdMapData = new Map();//每個checkbox對應的 appid,btnGroupId//保存數據this.checked = null;//標識數據是 新增 還是 刪除this.dataQueue = [];// appid,btngroupId隊列//測試數據this.appData = [{name: '報表',id: "456",key: '5', children: [{ name: '合同價款', id: "45xx61", key: '6', },{ name: '合同臺賬', id: "45xf61", key: '7', }], }, { name: '圖標', id: "789", key: '1', children: [{ name: '小圖標', id: "45xx60", key: '4' },{ name: '大圖標', id: "4xx560", key: '8' }] }];this.btnGroupColumns = [{id: '12xx3', name: '小部件', colname: 'name'}, {id:'43xx5', name:'顯示'}, {id:'43xfffx5', name:'test'}];}componentDidMount() {//const roleId = '4028968156b025da0156b027d0180000';const roleId = this.props.roleId;if(roleId) {//通過角色id加載 數據const { dispatch } = this.props;const querydata = {roleId: roleId};dispatch(queryRoleAppBtnData(querydata));}}componentWillReceiveProps(nextProps) {const {roleData} = nextProps;if (roleData.msg) {if(roleData.msg.indexOf('成功') >= 0)message.success(roleData.msg, 5);else if(roleData.msg.indexOf('失敗') >= 0)message.error(roleData.msg, 5);else message.info(roleData.msg, 5);// if (roleData.msg == '保存成功') {//角色保存成功后 仍然留在當前頁面, 繼續 角色按鈕組權限// this.props.history.pushState(null, 'rolecenter');// } }}chooseApp(){this.props.chooseApp();}sendCheckData(){const { dispatch } = this.props;const queryData = {vos: this.dataQueue,//對應后端的字段 };dispatch(operationRoleAppBtn(this.checked, queryData));}//// addChildrenRow(appData){//添加所有子行 標識if(!appData) return;for(var i=0; i<appData.length; ++i) {//獲取行頭的checkboxIdthis.rowNum++;//獲取行號var curRowHeadCheckboxId = appData[i].name.split('_')[1];var childrenRow = this.childrenRow;if(!childrenRow.get(curRowHeadCheckboxId)) childrenRow.put(curRowHeadCheckboxId, []);this.addChildrenRow(appData[i].children);childrenRow.get(curRowHeadCheckboxId).push(curRowHeadCheckboxId);//加入當前行if(appData[i].children) {//加入子行for(var j=0; j<appData[i].children.length; ++j) {var childCurRowHeadCheckboxId = appData[i].children[j].name.split('_')[1];var descendants = childrenRow.get(childCurRowHeadCheckboxId);//孫子們節點for(var k=0; k<descendants.length; ++k){childrenRow.get(curRowHeadCheckboxId).push(descendants[k]);}}}}}addDataPid(btnGroupColumns, appData) {//生成新的列, 并且為非表頭的每一個單元格設置固定 id,(防止表格渲染時 id發生變化)if(!appData) return;for(var i=0; i<appData.length; ++i) {for(var j=0; j<btnGroupColumns.length; ++j) {if(!appData[i][btnGroupColumns[j].colname]) {appData[i][btnGroupColumns[j].colname] = btnGroupColumns[j].id + '_' + (++this.cid);//為這一行數據添加新的列//判斷應用對應的按鈕是否已經選擇上, judgeDefaultCheckedif(appData[i].select && appData[i].select[btnGroupColumns[j].id]) {//btnGroupColumns[j].id == btnGroupIdthis.checkboxIdMapState.put(this.cid, true);} else {this.checkboxIdMapState.put(this.cid, false);}} else if(btnGroupColumns[j].colname == 'name'){if(appData[i][btnGroupColumns[j].colname].indexOf('_') >= 0) continue;appData[i][btnGroupColumns[j].colname] += '_' + (++this.cid);this.checkboxIdMapState.put(this.cid, false);}}this.addDataPid(btnGroupColumns, appData[i].children);}}addColName(btnGroupColumns, appData){if(btnGroupColumns) {btnGroupColumns.map((elem, index)=> { if(!elem.colname) {elem.colname = elem.id;}elem.cid = ++this.cid;});}if(appData) {this.addDataPid(btnGroupColumns, appData);/////清空數據var keySet = this.childrenRow.keySet();for(var key in keySet){if(this.childrenRow.get(keySet[key]) && this.childrenRow.get(keySet[key]).length)this.childrenRow.get(keySet[key]).length = 0;}/////總行數this.rowNum = 0;this.addChildrenRow(appData);++this.rowNum;/////判斷應用對應的checkbox是否選中,列頭對應的checkbox是否選中this.checkGroupAndColumnState();}}addData(cid, checked){var curCheckboxData = this.checkboxIdMapData.get(cid);if(curCheckboxData) {var curQueueData = {roleId: this.props.roleId,btnGroupId: curCheckboxData.btnGroupId,appId: curCheckboxData.appId,};this.dataQueue.push(curQueueData);}}isGroupRow(cid){//判斷是否為分組//第一行當做分組if(parseInt((cid-1)/this.colNum)*this.colNum+1 == 1) return true; const parentRow = this.parentRow;const childrenRow = this.childrenRow;var curRowHeadCheckboxId = parentRow.get(cid) ? parentRow.get(cid) : parseInt((cid-1)/this.colNum)*this.colNum+1;//通過cid 和 curRowHeadCheckboxId獲取到cid對應的checkbox到左邊的距離var rowIds = childrenRow.get(curRowHeadCheckboxId);//所有子行的行頭的 checkboxIdreturn rowIds.length > 1 ? true : false;}checkGroupAndColumnState() {const childrenRow = this.childrenRow;const checkboxIdMapState = this.checkboxIdMapState;const colNum = this.colNum;const rowNum = this.rowNum;const rowState = [];for(var i=0; i<=rowNum; ++i)rowState.push(true)//默認所有的行全選rowState[1] = false;for(var row=2; row <= rowNum; ++row) {var cb = (row-1)*colNum+2;//這一行從第2個 checkbox 開始if(this.isGroupRow(cb)) {//分組行,不算入rowState[row] = false;continue;}var ce = row*colNum;var curRowState = true;//默認這一行全選for(var cid=cb; cid<=ce; ++cid) {//遍歷這一行if(checkboxIdMapState.get(cid) == false) {curRowState = false;break;}}rowState[row] = curRowState;if(rowState[row] == true) {//應用對應的checkbox選中checkboxIdMapState.put((row-1)*colNum+1, true);} else {checkboxIdMapState.put((row-1)*colNum+1, false);}}//判斷分組是否選中for(var row=2; row <= rowNum; ++row) {const cid = (row-1)*colNum+1;//每一行的第一個if(!this.isGroupRow(cid)) continue;//計算分組行var cids = childrenRow.get(cid);var groupState = true;//默認這個分組被選中for(var i=0; i<cids.length; ++i){if(cids[i] != cid) {//不是分組行var cur_row = (cids[i]-1)/this.colNum+1;if(rowState[cur_row] == false) {groupState = false;break;}}}for(var cur_cid=cid; cur_cid <= row*colNum; ++cur_cid){//當前分組行的 checkbox 狀態 checkboxIdMapState.put(cur_cid, groupState);}if(groupState == false) {//如果當前分組行沒有狀態改變,查看這一行的某一個分組列是否有變化const childRowNum = cids.length-1;for(var curRowCid = cid; curRowCid<cid+this.colNum; ++curRowCid) {//遍歷這一分組行的checkboxIdvar curColState = true;for(var childRowCid = curRowCid+this.colNum, cnt = 0; cnt < childRowNum; childRowCid += this.colNum, ++cnt) {if(checkboxIdMapState.get(childRowCid) == false) {curColState = false;break;}}checkboxIdMapState.put(curRowCid, curColState);}}}// 判斷列 是否被選中if(rowNum > 1) {for(var col=1; col<=colNum; ++col) {var curColState = true;for(var cid=col+colNum; cid<=colNum*rowNum; cid+=colNum){if(checkboxIdMapState.get(cid) == false) {curColState = false;break;}}var cid = col;checkboxIdMapState.put(cid, curColState);//這一列的狀態 }}}onChecked(cid, btnGroupId, appId, checked){//checkboxId, 按鈕id,應用idconst checkboxIdMapState = this.checkboxIdMapState;const parentRow = this.parentRow;const parentCol = this.parentCol;const childrenRow = this.childrenRow;const colNum = this.colNum;const rowNum = this.rowNum;//清空數據隊列this.dataQueue.length = 0;//標識當前的操作this.checked = checked;if(btnGroupId == null && appId == null) {for(var cur_cid=1; cur_cid<=colNum*rowNum; ++cur_cid) {checkboxIdMapState.put(cur_cid, checked);if(!this.isGroupRow(cur_cid))this.addData(cur_cid, checked);}} else if(btnGroupId == null) {//appId 不為null, 這一行全選var rowHeadCheckboxIds = childrenRow.get(cid);//所有子行的行頭的 checkboxIdfor(var i=0; i<rowHeadCheckboxIds.length; ++i) {var cur_cid = rowHeadCheckboxIds[i];var cur_row_max_cid = parseInt(cur_cid) + colNum;while(cur_cid < cur_row_max_cid){checkboxIdMapState.put(cur_cid, checked);if(!this.isGroupRow(cur_cid))this.addData(cur_cid, checked);++cur_cid;}}} else if(appId == null) {//btnId不為null,這一列全部checkvar cur_cid = cid;while(cur_cid <= rowNum*colNum) {checkboxIdMapState.put(cur_cid, checked);if(!this.isGroupRow(cur_cid)) this.addData(cur_cid, checked);cur_cid += colNum;}} else {//都不為nullvar curRowHeadCheckboxId = parentRow.get(cid);//通過cid 和 curRowHeadCheckboxId獲取到cid對應的checkbox到左邊的距離var rowIds = childrenRow.get(curRowHeadCheckboxId);//所有子行的行頭的 checkboxIdfor(var i=0; i<rowIds.length; ++i) {//這一列全部checkvar cur_cid = parseInt(rowIds[i]) + (cid-curRowHeadCheckboxId);checkboxIdMapState.put(cur_cid, checked);if(!this.isGroupRow(cur_cid))this.addData(cur_cid, checked);}}this.setState({});this.sendCheckData();//發送數據 }//// render() {const appData = this.appData;const btnGroupColumns = this.btnGroupColumns;console.log(appData)let self = this;this.cid = 0;this.colNum = btnGroupColumns.length;//獲得列寬const checkboxIdMapState = this.checkboxIdMapState;const parentRow = this.parentRow;const parentCol = this.parentColif(btnGroupColumns) {this.addColName(btnGroupColumns, appData);//對應用的數據進行一個簡單的處理 btnGroupColumns.map((elem, index)=> { //elem.colname=='name' ? null : elem.id, 默認左上角的id 沒有 appId 和 btnGroupIdelem.title= <RoleCheckbox btnGroupId={elem.colname=='name' ? null : elem.id} appId={null} cid={elem.cid} onChecked={self.onChecked} checked={checkboxIdMapState.get(elem.cid)} title={elem.name}/>,elem.key = elem.dataIndex = elem.colname;elem.render = function(text, record, index){// text的值 == 對應表頭列的Id == elem.idvar contents = text.split('_');text = contents[0];var cur_cid = contents[1];//當前列頂端 checkboxId//判斷是否是第一列if(record.name.split('_')[0] != text) {//不是第一列var leftCheckBoxId = record.name.split('_')[1];parentRow.put(cur_cid, leftCheckBoxId);//該 checkboxId 對應的 (應用Id == leftCheckBoxId)//加入每個checkbox 要傳輸的數據(appId, btnGroupId) self.checkboxIdMapData.put(cur_cid, {appId: record.id, btnGroupId: elem.id})}//該 checkboxId 對應的 最上邊的 checkboxIdparentCol.put(cur_cid, elem.cid);//該 checkboxId 對應的 (按鈕Id == elem.cid)//record.name.split('_')[0] 最原始的 name 的valuereturn <RoleCheckbox btnGroupId={record.name.split('_')[0] == text ? null : elem.id} appId={record.id} cid={cur_cid} onChecked={self.onChecked} checked={checkboxIdMapState.get(cur_cid)} title={text==elem.id ? null : text}/> }});}return (<div><Btn iconName="icon-add" onClick={this.chooseApp} btnClass="add-btn" btnName="選擇應用"/><Table indentSize={15}className="personType-table" columns={btnGroupColumns} dataSource={appData} pagination={false}/></div> );} } module.exports = RoleApplicationTable; RoleApplicationTable.propTypes = propTypes; module.exports = connect(mapStateToProps)(RoleApplicationTable); View Code

  利用antd table實現層級多選組件。

  具體思路:

addDataPid(btnGroupColumns, appData) {//生成新的列, 并且為非表頭的每一個單元格設置固定 id,(防止表格渲染時 id發生變化)if(!appData) return;for(var i=0; i<appData.length; ++i) {for(var j=0; j<btnGroupColumns.length; ++j) {if(!appData[i][btnGroupColumns[j].colname]) {appData[i][btnGroupColumns[j].colname] = btnGroupColumns[j].id + '_' + (++this.cid);//為這一行數據添加新的列//判斷應用對應的按鈕是否已經選擇上, judgeDefaultCheckedif(appData[i].select && appData[i].select[btnGroupColumns[j].id]) {//btnGroupColumns[j].id == btnGroupIdthis.checkboxIdMapState.put(this.cid, true);} else {this.checkboxIdMapState.put(this.cid, false);}} else if(btnGroupColumns[j].colname == 'name'){if(appData[i][btnGroupColumns[j].colname].indexOf('_') >= 0) continue;appData[i][btnGroupColumns[j].colname] += '_' + (++this.cid);this.checkboxIdMapState.put(this.cid, false);}}this.addDataPid(btnGroupColumns, appData[i].children);} }addColName(btnGroupColumns, appData){//為每一列添加 映射字段 colnameif(btnGroupColumns) {btnGroupColumns.map((elem, index)=> { if(!elem.colname) {elem.colname = elem.id;}elem.cid = ++this.cid;});}if(appData) {this.addDataPid(btnGroupColumns, appData);/////清空數據var keySet = this.childrenRow.keySet();for(var key in keySet){if(this.childrenRow.get(keySet[key]) && this.childrenRow.get(keySet[key]).length)this.childrenRow.get(keySet[key]).length = 0;}/////總行數this.rowNum = 0;this.addChildrenRow(appData);++this.rowNum;/////判斷應用對應的checkbox是否選中,列頭對應的checkbox是否選中this.checkGroupAndColumnState();} }

?

  2.RoleCheckbox.js

import {Checkbox} from 'antd'; import React from 'react'; class RoleCheckbox extends React.Component{constructor(props) {super(props);this.onChange = this.onChange.bind(this);}onChange(e){const cid = this.props.cid;const btnGroupId = this.props.btnGroupId;const appId = this.props.appId;this.props.onChecked(cid, btnGroupId, appId, e.target.checked);}render() {const checked = this.props.checked;const title = this.props.title;const cid = this.props.cid;return(<div><Checkbox checked={checked} onChange={this.onChange}/>{title}</div> );} } module.exports = RoleCheckbox; View Code

?  封裝antd 的Checkbox組件

  3.Map.js

class Map {constructor(){this.container = new Object();}put(key, value){this.container[key] = value;}get(key){return this.container[key];}keySet() {var keyset = new Array();var count = 0;for (var key in this.container) {// 跳過object的extend函數if (key == 'extend') {continue;}keyset[count] = key;count++;}return keyset;}size() {var count = 0;for (var key in this.container) {// 跳過object的extend函數if (key == 'extend'){continue;}count++;}return count;}remove(key) {delete this.container[key];}toString(){var str = "";for (var i = 0, keys = this.keySet(), len = keys.length; i < len; i++) {str = str + keys[i] + "=" + this.container[keys[i]] + ";\n";}return str;} }module.exports = Map; View Code

  js實現的Map工具類。

?四、需求變更

  功能雖然完成了,但是總是避免不了需求的變更。要求選擇左邊應用對應的checkbox時,不在操作該應用對應的按鈕的checkbox,也就是整個行不是全選了。應用對應的checkbox用來進行刪除操作。

  1.改變后的Table效果

  

  2.RoleApplicationTable.js

import React from 'react'; import RoleCheckbox from 'components/role/RoleCheckbox'; import {Menu, Table, message, Modal} from 'antd'; const confirm = Modal.confirm; import Btn from 'components/public/BaseBtn'; import {connect} from 'react-redux'; import 'styles/less/personType.less'; import 'styles/less/basebtn.less'; import Map from 'components/role/Map'; import { operationRoleAppBtn, queryRoleAppBtnData, deleteAppAction} from 'actions/role';var mapStateToProps = function(state){return {roleData: state.getRole } }; //規范屬性類型 var propTypes = {personTypes: React.PropTypes.object,dispatch : React.PropTypes.func }; class RoleApplicationTable extends React.Component {constructor(props) {super(props);this.state = {isEdit: true,};this.chooseApp = this.chooseApp.bind(this);this.addColName = this.addColName.bind(this);this.addDataPid = this.addDataPid.bind(this);this.onChecked = this.onChecked.bind(this);this.addChildrenRow = this.addChildrenRow.bind(this);this.addAppBtnData = this.addAppBtnData.bind(this);this.addAppData = this.addAppData.bind(this);this.isGroupRow = this.isGroupRow.bind(this);this.checkGroupAndColumnState = this.checkGroupAndColumnState.bind(this);//確保 組全選 和 列 全選this.deleteApp = this.deleteApp.bind(this);this.showConfirm = this.showConfirm.bind(this);this.initRoleAppBtnData = this.initRoleAppBtnData.bind(this);this.cancelChooseState = this.cancelChooseState.bind(this);this.saveCheckedAppBtn = this.saveCheckedAppBtn.bind(this);this.afterSaveCheckedAppBtn = this.afterSaveCheckedAppBtn.bind(this);this.cid = 0;this.rowNum = 0;this.colNum = 0;//mapthis.checkboxIdMapState= new Map();//checkboxId 映射 Statethis.parentRow = new Map();//每個checkboxId節點 對應最左邊的哪個應用this.parentCol = new Map();//每個checkboxId節點 對應最上邊的哪個按鈕this.childrenRow = new Map();//當前行的所有子行this.checkboxIdMapAppBtnData = new Map();//每個checkbox對應的 appid,btnGroupIdthis.checkboxIdMapAppData = new Map();//記錄被選中的應用//保存數據this.dataQueue = [];// appid,btngroupId隊列//刪除應用this.deleteAppIds = [];//測試數據this.appData = [{name: '報表',id: "456",key: '5', children: [{ name: '合同價款', id: "45xx61", key: '6', },{ name: '合同臺賬', id: "45xf61", key: '7', }], }, { name: '圖標', id: "789", key: '1', children: [{ name: '小圖標', id: "45xx60", key: '4' },{ name: '大圖標', id: "4xx560", key: '8' }] }];this.btnGroupColumns = [{id: '12xx3', name: '小部件', colname: 'name'}, {id:'43xx5', name:'顯示'}, {id:'43xfffx5', name:'test'}];}//確認提示框 showConfirm(title,message,dispatch,functionT,functionQueryData) {confirm({title: title,content: message,onOk() {dispatch(functionT(functionQueryData)); },onCancel() {}});}componentDidMount() {//const roleId = '4028968156b025da0156b027d0180000';this.initRoleAppBtnData();}initRoleAppBtnData(){const roleId = this.props.roleId;if(roleId) {//通過角色id加載 數據const { dispatch } = this.props;const querydata = {roleId: roleId};dispatch(queryRoleAppBtnData(querydata));}}cancelChooseState(){//取消權限的更改this.initRoleAppBtnData();}componentWillReceiveProps(nextProps) {const {roleData} = nextProps;if (roleData.msg) {if(roleData.msg.indexOf('成功') >= 0)message.success(roleData.msg, 5);else if(roleData.msg.indexOf('失敗') >= 0)message.error(roleData.msg, 5);else message.info(roleData.msg, 5);// if (roleData.msg == '保存成功') {//角色保存成功后 仍然留在當前頁面, 繼續 角色按鈕組權限// this.props.history.pushState(null, 'rolecenter');// } }}chooseApp(){this.props.chooseApp();}sendCheckData(){const { dispatch } = this.props;const queryData = {'vos': this.dataQueue,//對應后端的字段'roleId': this.props.roleId,};dispatch(operationRoleAppBtn(queryData, this.afterSaveCheckedAppBtn));}//// addChildrenRow(appData){//添加所有子行 標識if(!appData) return;for(var i=0; i<appData.length; ++i) {//獲取行頭的checkboxIdthis.rowNum++;//獲取行號var curRowHeadCheckboxId = appData[i].name.split('_')[1];var childrenRow = this.childrenRow;if(!childrenRow.get(curRowHeadCheckboxId)) childrenRow.put(curRowHeadCheckboxId, []);this.addChildrenRow(appData[i].children);childrenRow.get(curRowHeadCheckboxId).push(curRowHeadCheckboxId);//加入當前行if(appData[i].children) {//加入子行for(var j=0; j<appData[i].children.length; ++j) {var childCurRowHeadCheckboxId = appData[i].children[j].name.split('_')[1];var descendants = childrenRow.get(childCurRowHeadCheckboxId);//孫子們節點for(var k=0; k<descendants.length; ++k){childrenRow.get(curRowHeadCheckboxId).push(descendants[k]);}}}}}addDataPid(btnGroupColumns, appData) {//生成新的列, 并且為非表頭的每一個單元格設置固定 id,(防止表格渲染時 id發生變化)if(!appData) return;for(var i=0; i<appData.length; ++i) {for(var j=0; j<btnGroupColumns.length; ++j) {if(!appData[i][btnGroupColumns[j].colname]) {appData[i][btnGroupColumns[j].colname] = btnGroupColumns[j].id + '_' + (++this.cid);//為這一行數據添加新的列//判斷應用對應的按鈕是否已經選擇上, judgeDefaultCheckedif(appData[i].select && appData[i].select[btnGroupColumns[j].id]) {//btnGroupColumns[j].id == btnGroupIdthis.checkboxIdMapState.put(this.cid, true);} else {this.checkboxIdMapState.put(this.cid, false);}} else if(btnGroupColumns[j].colname == 'name'){if(appData[i][btnGroupColumns[j].colname].indexOf('_') >= 0) continue;appData[i][btnGroupColumns[j].colname] += '_' + (++this.cid);this.checkboxIdMapState.put(this.cid, false);}}this.addDataPid(btnGroupColumns, appData[i].children);}}addColName(btnGroupColumns, appData){if(btnGroupColumns) {btnGroupColumns.map((elem, index)=> { if(!elem.colname) {elem.colname = elem.id;}elem.cid = ++this.cid;});}if(appData) {this.addDataPid(btnGroupColumns, appData);/////清空數據var keySet = this.childrenRow.keySet();for(var key in keySet){if(this.childrenRow.get(keySet[key]) && this.childrenRow.get(keySet[key]).length)this.childrenRow.get(keySet[key]).length = 0;}/////總行數this.rowNum = 0;this.addChildrenRow(appData);++this.rowNum;/////判斷應用對應的checkbox是否選中,列頭對應的checkbox是否選中this.checkGroupAndColumnState();}}addAppBtnData(cid){var curCheckboxData = this.checkboxIdMapAppBtnData.get(cid);if(curCheckboxData) {var curQueueData = {roleId: this.props.roleId,btnGroupId: curCheckboxData.btnGroupId,appId: curCheckboxData.appId,};this.dataQueue.push(curQueueData);}}addAppData(cid){var checked = this.checkboxIdMapState.get(cid);if(checked == false) return;var curAppId = this.checkboxIdMapAppData.get(cid);if(curAppId) {var curQueueData = {roleId: this.props.roleId,appId: curAppId,};this.deleteAppIds.push(curQueueData);}}isGroupRow(cid){//判斷是否為分組//第一行當做分組if(parseInt((cid-1)/this.colNum)*this.colNum+1 == 1) return true; const parentRow = this.parentRow;const childrenRow = this.childrenRow;var curRowHeadCheckboxId = parentRow.get(cid) ? parentRow.get(cid) : parseInt((cid-1)/this.colNum)*this.colNum+1;//通過cid 和 curRowHeadCheckboxId獲取到cid對應的checkbox到左邊的距離var rowIds = childrenRow.get(curRowHeadCheckboxId);//所有子行的行頭的 checkboxIdreturn rowIds.length > 1 ? true : false;}checkGroupAndColumnState() {const childrenRow = this.childrenRow;const checkboxIdMapState = this.checkboxIdMapState;const colNum = this.colNum;const rowNum = this.rowNum;const rowState = [];for(var i=0; i<=rowNum; ++i)rowState.push(true)//默認所有的行全選rowState[1] = false;//判斷分組列for(var row=2; row <= rowNum; ++row) {const cid = (row-1)*colNum+1;//每一行的第一個if(!this.isGroupRow(cid)) continue;var cids = childrenRow.get(cid);const childRowNum = cids.length-1;for(var curRowCid = cid; curRowCid<cid+this.colNum; ++curRowCid) {//遍歷這一分組行的checkboxIdvar curColState = true;for(var childRowCid = curRowCid+this.colNum, cnt = 0; cnt < childRowNum; childRowCid += this.colNum, ++cnt) {if(checkboxIdMapState.get(childRowCid) == false) {curColState = false;break;}}checkboxIdMapState.put(curRowCid, curColState);}}// 判斷列 是否被選中if(rowNum > 1) {for(var col=1; col<=colNum; ++col) {var curColState = true;for(var cid=col+colNum; cid<=colNum*rowNum; cid+=colNum){if(checkboxIdMapState.get(cid) == false) {curColState = false;break;}}var cid = col;checkboxIdMapState.put(cid, curColState);//這一列的狀態 }} else if(rowNum == 1) {//每一列的狀態清空for(var cid = 1; cid <= this.colNum; ++cid)checkboxIdMapState.put(cid, false);}}onChecked(cid, btnGroupId, appId, checked){//checkboxId, 按鈕id,應用idif(this.state.isEdit == true && cid%this.colNum != 1) {//第一列為應用列,隨時可以編輯message.info('請進入編輯狀態', 2);return ;}const checkboxIdMapState = this.checkboxIdMapState;const parentRow = this.parentRow;const parentCol = this.parentCol;const childrenRow = this.childrenRow;const colNum = this.colNum;const rowNum = this.rowNum;if(btnGroupId == null && appId == null) {for(var cur_cid=1; cur_cid<=colNum*rowNum; cur_cid+=colNum) {checkboxIdMapState.put(cur_cid, checked);}} else if(btnGroupId == null) {//appId 不為null, 所有的子應用全選var rowHeadCheckboxIds = childrenRow.get(cid);//所有子行的行頭的 checkboxId(對應應用)for(var i=0; i<rowHeadCheckboxIds.length; ++i) {var cur_cid = rowHeadCheckboxIds[i];checkboxIdMapState.put(cur_cid, checked);}} else if(appId == null) {//btnId不為null,這一列全部checkvar cur_cid = cid;while(cur_cid <= rowNum*colNum) {checkboxIdMapState.put(cur_cid, checked);cur_cid += colNum;}} else {//都不為nullvar curRowHeadCheckboxId = parentRow.get(cid);//通過cid 和 curRowHeadCheckboxId獲取到cid對應的checkbox到左邊的距離var rowIds = childrenRow.get(curRowHeadCheckboxId);//所有子行的行頭的 checkboxIdfor(var i=0; i<rowIds.length; ++i) {//這一列全部checkvar cur_cid = parseInt(rowIds[i]) + (cid-curRowHeadCheckboxId);checkboxIdMapState.put(cur_cid, checked);}}this.setState({});}deleteApp(){this.deleteAppIds.length = 0;//清空數據const {dispatch} = this.props;for(var cid = 1; cid <= this.rowNum*this.colNum; cid += this.colNum) {if(!this.isGroupRow(cid)) {this.addAppData(cid);}}if(this.deleteAppIds.length == 0) {message.success('請選擇應用', 5);return;}const queryData = {vos: this.deleteAppIds,}this.showConfirm('刪除應用', '確定刪除應用?', dispatch, deleteAppAction, queryData); }afterSaveCheckedAppBtn(){this.setState({isEdit: true,});}saveCheckedAppBtn(){if(this.state.isEdit == true) {this.setState({isEdit: false,});return ;} //清空數據隊列this.dataQueue.length = 0;for(var cid = this.colNum+1; cid <= this.colNum*this.rowNum; ++cid) {//從第二行的checkbox 開始if(this.isGroupRow(cid)) {cid += this.colNum;}if(cid%this.colNum != 1) {//第一列為 應用列if(this.checkboxIdMapState.get(cid) == true)this.addAppBtnData(cid);}}this.sendCheckData();}//// render() {let {roleData} = this.props;var appData = [];var btnGroupColumns = [];if(roleData.permissiondData) {if(roleData.permissiondData.listAppBtnGroup) {btnGroupColumns = roleData.permissiondData.listAppBtnGroup;}if(roleData.permissiondData.listPermissionApp) {appData = roleData.permissiondData.listPermissionApp;}}// const appData = this.appData;// const btnGroupColumns = this.btnGroupColumns;// console.log(appData)let self = this;this.cid = 0;this.colNum = btnGroupColumns.length;//獲得列寬const checkboxIdMapState = this.checkboxIdMapState;const parentRow = this.parentRow;const parentCol = this.parentColif(btnGroupColumns) {this.addColName(btnGroupColumns, appData);//對應用的數據進行一個簡單的處理 btnGroupColumns.map((elem, index)=> { //elem.colname=='name' ? null : elem.id, 默認左上角的id 沒有 appId 和 btnGroupIdelem.title= <RoleCheckbox btnGroupId={elem.colname=='name' ? null : elem.id} appId={null} cid={elem.cid} onChecked={self.onChecked} checked={checkboxIdMapState.get(elem.cid)} title={elem.name}/>,elem.key = elem.dataIndex = elem.colname;elem.render = function(text, record, index){// text的值 == 對應表頭列的Id == elem.idvar contents = text.split('_');text = contents[0];var cur_cid = contents[1];//當前列頂端 checkboxId//判斷是否是第一列if(record.name.split('_')[0] != text) {//不是第一列var leftCheckBoxId = record.name.split('_')[1];parentRow.put(cur_cid, leftCheckBoxId);//該 checkboxId 對應的 (應用Id == leftCheckBoxId)//加入每個checkbox 要傳輸的數據(appId, btnGroupId) self.checkboxIdMapAppBtnData.put(cur_cid, {appId: record.id, btnGroupId: elem.id})} else {//應用列 self.checkboxIdMapAppData.put(cur_cid, record.id);}//該 checkboxId 對應的 最上邊的 checkboxIdparentCol.put(cur_cid, elem.cid);//該 checkboxId 對應的 (按鈕Id == elem.cid)//record.name.split('_')[0] 最原始的 name 的valuereturn <RoleCheckbox btnGroupId={record.name.split('_')[0] == text ? null : elem.id} appId={record.id} cid={cur_cid} onChecked={self.onChecked} checked={checkboxIdMapState.get(cur_cid)} title={text==elem.id ? null : text}/> }});}return (<div><Btn iconName="icon-add" isdisabled={self.props.roleId ? false : true} onClick={this.chooseApp} btnClass="add-btn" btnName="選擇應用"/>&nbsp;&nbsp;&nbsp;&nbsp;<Btn iconName="icon-jianhao" isdisabled={self.props.roleId ? false : true} btnClass="delete-btn" btnName="刪除應用" onClick={self.deleteApp}/> <Table style={{marginTop: "10px", marginBottom: "10px"}}indentSize={15}className="personType-table" columns={btnGroupColumns} dataSource={appData} pagination={false}/><div style={{display: self.rowNum > 1 ? '' : 'none'}}><Btn btnClass="save-btn" btnName={self.state.isEdit == true ? "編輯" : "保存"} onClick={this.saveCheckedAppBtn}/>&nbsp;&nbsp;&nbsp;&nbsp;<Btn btnClass="cancel-btn" btnName="取消" onClick={self.cancelChooseState}/></div></div> );} } module.exports = RoleApplicationTable; RoleApplicationTable.propTypes = propTypes; module.exports = connect(mapStateToProps)(RoleApplicationTable); View Code

五、心得體會

  最近使用react + redux + webpack進行web開發,感覺進步很快,已經熟悉了基本的流程。后續要研究一下webpack。

轉載于:https://www.cnblogs.com/hujunzheng/p/5812046.html

總結

以上是生活随笔為你收集整理的React使用antd Table生成层级多选组件的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

天天干天天综合 | 国产福利一区二区三区在线观看 | 五月天视频网 | 夜夜操综合网 | 热久久在线视频 | 精品久久一区二区 | 精品伦理一区二区三区 | 激情在线五月天 | 亚洲第一伊人 | 国产精品第二页 | 婷婷色av| 久久8精品 | 色综合久久综合中文综合网 | 国产黄色一级大片 | 91视频高清免费 | 久久激情网站 | 免费日韩一区二区三区 | 欧美大香线蕉线伊人久久 | 中文字幕在线免费观看 | 在线电影中文字幕 | www.久久婷婷 | 99久久精品免费看国产一区二区三区 | 国产在线视频一区二区 | 黄色a级片在线观看 | 黄色三级网站在线观看 | 日韩欧美视频一区二区 | 国产原厂视频在线观看 | 国产高清视频在线免费观看 | 日本在线中文 | av超碰在线 | 日韩欧美在线视频一区二区 | 国产精品久久久久久久久大全 | 黄色成人免费电影 | 欧美一进一出抽搐大尺度视频 | 日韩久久精品一区 | av一级在线观看 | 天天射夜夜爽 | 日韩久久久 | 免费黄色av片 | a级片韩国 | 亚洲精品国产精品乱码不99热 | 久久99国产综合精品免费 | 99在线高清视频在线播放 | 人人添人人| 日本婷婷色 | 一区二区三区在线免费观看 | av三级av| 国产片免费在线观看视频 | 欧美做受高潮 | 日日色综合 | 国产黄色免费电影 | 日韩区视频 | 精品国产一区二区三区久久久久久 | 性色大片在线观看 | 久久在线免费 | 黄色免费在线看 | 主播av在线| 成人av网址大全 | 日本夜夜草视频网站 | 天天视频亚洲 | 黄色在线免费观看网址 | 亚洲综合色av | 日韩免费在线观看视频 | 久久人人爽人人人人片 | 九七视频在线观看 | 91视频免费 | 色在线视频 | 中文字幕91视频 | 日韩精品中文字幕在线不卡尤物 | 激情视频一区二区三区 | 国产精品9999久久久久仙踪林 | 国产精品不卡在线 | 欧美一级免费 | 日日狠狠 | 99精品免费久久久久久久久日本 | 日本大片免费观看在线 | av大片免费看 | 成人午夜久久 | 国产中文字幕大全 | 国产在线观看h | 91麻豆传媒| 亚洲成熟女人毛片在线 | 91精品啪在线观看国产81旧版 | 亚洲国产精品视频在线观看 | 成人黄色av免费在线观看 | 亚洲视频精品在线 | 91成人观看 | 激情五月婷婷综合网 | 久久公开视频 | 高清不卡一区二区在线 | 91亚洲精品久久久蜜桃 | 最近中文字幕视频完整版 | 天天干 夜夜操 | av日韩国产| 国产手机精品视频 | 96精品视频 | 蜜臀av网址 | 亚洲综合五月天 | 亚洲精品乱码久久 | 国产拍在线 | 日韩理论电影在线观看 | 高潮毛片无遮挡高清免费 | 综合av在线| 九九亚洲精品 | 色av网站 | 久久综合操 | 色av男人的天堂免费在线 | 国产亚洲精品久久久久久移动网络 | 黄色网中文字幕 | 美女视频黄在线观看 | 在线观看久草 | 日韩综合一区二区 | 日韩在线精品 | 最新动作电影 | 激情小说网站亚洲综合网 | 国产伦理精品一区二区 | 伊人狠狠色 | 在线成人短视频 | 黄色网在线播放 | 日日久视频 | 成人av电影免费观看 | 天天插天天狠天天透 | 国产在线观看二区 | 亚洲在线综合 | 国内精品久久久久 | 一区二区三区免费看 | 天堂中文在线播放 | 麻豆传媒在线免费看 | 色婷婷成人网 | 五月婷激情 | 手机看片久久 | 天天爱天天操天天爽 | 国产精品麻豆果冻传媒在线播放 | 日韩免费在线观看视频 | 97在线免费视频观看 | 色婷婷狠狠五月综合天色拍 | 麻豆影视网站 | 天天操天天干天天综合网 | 中文字幕一区二区在线观看 | 欧美日韩一级在线 | 伊人中文网 | 黄色在线看网站 | 国产精品一区二区吃奶在线观看 | 精油按摩av | 精品在线视频观看 | 欧美国产日韩一区二区三区 | 免费av影视 | 奇米影视8888 | 美女网站视频免费都是黄 | 香蕉在线影院 | 日韩精品 在线视频 | 欧美人人爱 | 丁香影院在线 | 五月婷婷欧美视频 | 久久66热这里只有精品 | 精品一区欧美 | 久久伊人爱 | 国产一区免费看 | 久久久美女| 最近更新中文字幕 | 亚洲乱亚洲乱亚洲 | 欧美性黄网官网 | 九九热久久免费视频 | 国产精品自产拍在线观看网站 | 日韩精品你懂的 | 国产二区免费视频 | 91视频网址入口 | 中文字幕在线观看播放 | 丁香花在线观看免费完整版视频 | 国产一级片免费播放 | 国产精品久久久久久久久久久久午夜片 | 91麻豆精品国产91久久久使用方法 | 久久九九精品久久 | 在线亚洲成人 | 国产精品福利视频 | 亚洲国产日韩欧美 | 国产原创在线 | 在线欧美小视频 | 亚洲精品动漫成人3d无尽在线 | 一区二区伦理 | 国产精品日韩在线观看 | 国产无区一区二区三麻豆 | 特级西西人体444是什么意思 | 日本三级吹潮在线 | www.夜夜爱| 日韩精品欧美专区 | 99九九免费视频 | 久久精品人人做人人综合老师 | 97超碰成人在线 | 91av视频免费在线观看 | 天天综合天天做天天综合 | 中文字幕亚洲高清 | 国产视频精品网 | 成人亚洲精品久久久久 | 亚洲成色777777在线观看影院 | 日韩理论片在线 | 91av观看| 日韩在线看片 | av一级一片 | 久精品视频免费观看2 | 天天鲁天天干天天射 | 欧美久久久久久久久中文字幕 | 免费视频一二三区 | 久久草草热国产精品直播 | 亚洲日韩中文字幕 | 亚洲黄色免费 | 日韩av手机在线观看 | 伊人色综合久久天天网 | 亚洲欧美综合精品久久成人 | 一级黄色片毛片 | 黄色av免费看 | 久久精品之| 精品高清美女精品国产区 | 亚洲精品乱码久久久久久蜜桃91 | 激情欧美一区二区三区 | 欧美大片大全 | 五月婷影院 | 中文字幕 国产视频 | 免费久久精品视频 | 日韩在线观看av | 成人影片免费 | 中文字幕日韩伦理 | 在线观看免费91 | 这里有精品在线视频 | 草久在线播放 | 视频一区二区在线 | 九九热免费视频在线观看 | 狠狠干狠狠久久 | www.com.日本一级 | 五月婷婷视频在线观看 | 欧美精品在线观看免费 | 日日爱影视 | 久久久www成人免费毛片麻豆 | 国产精品热 | 波多野结衣网址 | 成人在线免费看视频 | 国产精品完整版 | 麻豆视频免费在线播放 | 国产日产精品一区二区三区四区 | 国产亚洲精品久久网站 | 国产精品99免费看 | 日本夜夜草视频网站 | 色婷婷激情| 久久无码精品一区二区三区 | 五月婷在线观看 | 日韩伦理一区二区三区av在线 | 国内精品免费 | 人人插人人搞 | 在线有码中文字幕 | 国产成人av在线影院 | 久草综合视频 | 91九色蝌蚪国产 | 国产精品久久久毛片 | 亚洲日本中文字幕在线观看 | 亚洲视频电影在线 | 亚洲成人一二三 | 日韩免费在线播放 | 又爽又黄又刺激的视频 | 在线免费精品视频 | 91av电影在线观看 | 精品国产伦一区二区三区免费 | 成人在线免费视频 | 伊人天天| 最近中文字幕 | 91成人看片 | 91探花系列在线播放 | 亚洲精品中文在线资源 | 成人在线观看资源 | 三级黄色网址 | 国产成人在线免费观看 | 免费黄色激情视频 | 日韩精品久久久久久久电影99爱 | 国产理论影院 | 99久久久国产精品免费99 | 久久久久久国产精品免费 | 99精品视频免费看 | 亚洲精选在线观看 | 五月天综合在线 | 亚洲在线网址 | 久久综合婷婷综合 | 色视频在线免费观看 | 91丨porny丨九色 | 在线观看av中文字幕 | 99久久精品久久亚洲精品 | av在线电影免费观看 | 精品国产日本 | 日本公妇色中文字幕 | 色成人亚洲网 | 日一日干一干 | 91av大全 | 成x99人av在线www | 美女搞黄国产视频网站 | 99精品久久久久 | 日本大尺码专区mv | 国产91勾搭技师精品 | 69视频在线 | 激情综合色图 | 久久免费视频8 | 日本精品中文字幕在线观看 | 精品国内 | 婷婷丁香五 | 国产中文字幕在线 | 欧美成人69av | 久久久久一区二区三区 | 国产在线色 | www.狠狠操.com | 欧美美女激情18p | 日韩av电影一区 | 欧美一级电影免费观看 | 天天激情 | 毛片基地黄久久久久久天堂 | 97超碰在线视 | 中文字幕精品一区二区三区电影 | 97电影在线观看 | 欧美成年人在线视频 | 欧美一区二区三区激情视频 | 国产999视频在线观看 | 亚洲综合色丁香婷婷六月图片 | 中文一区二区三区在线观看 | 高清av在线 | 精品国产乱码 | 99久久精品免费看国产一区二区三区 | 日本中文字幕高清 | 91免费日韩 | 美女网站黄免费 | 91探花在线 | 99精品视频一区 | 黄色a级片在线观看 | 最近中文字幕大全中文字幕免费 | av电影不卡在线 | 久久国产精品免费看 | av色图天堂网 | 精品伦理一区二区三区 | 婷婷天天色 | 干天天 | 亚洲国产手机在线 | 欧美日韩国产一二 | 天天爱综合 | 久久国产精品久久国产精品 | av电影在线观看完整版一区二区 | 国产日韩欧美视频在线观看 | 久久精品一区二区三 | 成人综合日日夜夜 | 亚洲高清精品在线 | 国产精品免费视频久久久 | 日韩免费电影 | 国产一在线精品一区在线观看 | 中国一级片免费看 | 国产成人免费 | 中文字幕一区二区三区四区久久 | 欧美伦理一区 | 国产又粗又猛又爽又黄的视频先 | 国产精品亚洲人在线观看 | 天天天天爱天天躁 | 免费在线观看成人av | 国产专区视频在线观看 | 国产啊v在线 | 在线看日韩 | 天堂va欧美va亚洲va老司机 | 超碰在线色 | 国产在线 一区二区三区 | 人人草在线视频 | 国产亚洲精品久久久久久网站 | 中文字幕精品一区二区三区电影 | 成人av在线直播 | 精品一区免费 | 国产高清视频免费最新在线 | 在线免费国产 | 91精品久久久久久久久久久久久 | 久久99精品久久只有精品 | 色偷偷97| 国产精品久久一区二区无卡 | 白丝av在线| 国产精品资源在线观看 | 91网在线观看 | 午夜免费福利视频 | 久久成人在线视频 | 91九色综合 | 99久国产| 久久影视中文字幕 | 少妇搡bbbb搡bbb搡忠贞 | 中文字幕黄色网 | 91漂亮少妇露脸在线播放 | 国产区久久 | 国产精品久久久久久久久久久久午 | 手机看片午夜 | 欧洲精品一区二区 | 黄色国产精品 | 中国一区二区视频 | 成人超碰97 | 免费视频二区 | 97人人模人人爽人人少妇 | 日韩av线观看 | 91精品国产网站 | 色av资源网 | 国产美女精品视频免费观看 | 天天天干天天天操 | 顶级bbw搡bbbb搡bbbb | 97在线视频免费 | 日韩精品中文字幕久久臀 | 国产中文欧美日韩在线 | 久久久久视| 天天激情天天干 | 国产一二三区在线观看 | 国产黄色特级片 | 久久久免费精品国产一区二区 | 中文字幕精品www乱入免费视频 | 天天躁日日 | 国产日韩欧美在线播放 | 九月婷婷综合网 | 欧美韩国在线 | 亚洲婷婷免费 | 伊人久久婷婷 | 日韩中文字幕免费电影 | 96精品视频| 91探花在线视频 | 国产成人精品一区二区三区网站观看 | 午夜999| 久久午夜影院 | 亚洲精品视频二区 | 中文字幕 二区 | 91手机电视 | 天天做日日做天天爽视频免费 | 在线电影 一区 | 免费久久久久久 | 91成品视频 | 亚洲影院一区 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 国产精品亚 | 天天艹天天爽 | 中文字幕在线播放视频 | 麻豆 videos| 午夜骚影| 成年人视频免费在线播放 | 亚洲视频 在线观看 | 中文字幕中文字幕在线中文字幕三区 | 99精品视频免费全部在线 | 97人人澡人人添人人爽超碰 | 天天做天天爱天天综合网 | 黄色片网站av | 亚洲男男gaygay无套同网址 | 黄网站app在线观看免费视频 | 国产精品一区二区免费在线观看 | 久久dvd | 天天操夜夜操夜夜操 | 国产视频精品视频 | 欧美在线观看视频一区二区 | 久久经典国产视频 | 日韩网站在线 | a国产精品 | 久久婷婷色 | 国精产品999国精产品岳 | 综合网五月天 | 99热国内精品 | 激情xxxx| www.五月天色 | 天天干天天射天天插 | 久久久久久久亚洲精品 | 97国产精品| 久草在线一免费新视频 | 日b视频在线观看网址 | 久久精品久久99精品久久 | 久久久久欧美精品999 | 99久久日韩精品视频免费在线观看 | 亚洲蜜桃在线 | 色播五月激情五月 | 久久精品直播 | 91天堂影院| 国产最新在线 | 九色视频网址 | 国产一卡二卡在线 | 亚洲精品福利视频 | 97国产超碰在线 | 狠狠色丁香婷婷综合欧美 | 成人av在线影视 | 91在线观 | 久草网免费 | 五月天丁香视频 | 久久国产欧美日韩 | 午夜在线日韩 | 亚洲欧美日本一区二区三区 | 天天干人人插 | 国产91精品久久久久久 | 精品爱爱 | 久久成人综合 | 色a网| www.天天色.com | 中文字幕乱码日本亚洲一区二区 | 亚洲综合情 | 精品国产精品久久一区免费式 | 欧美婷婷综合 | 日韩理论片在线 | 国内精品视频久久 | 欧美午夜精品久久久久 | 免费人成在线观看网站 | 亚洲区精品| 国产精品永久免费观看 | 日韩影片在线观看 | 97超碰中文字幕 | 亚洲国产日韩一区 | 91精品久久久久久久久 | 久久精品国产精品亚洲 | 欧美一级性生活视频 | 成人黄色免费在线观看 | 国产在线中文 | 亚洲成人av电影在线 | 久久日韩精品 | 91麻豆精品国产91久久久久久久久 | 91热这里只有精品 | 国产精品一区免费在线观看 | 就要干b | 人人搞人人干 | 一区二区精品在线 | 看毛片网站 | 一级黄色大片在线观看 | 久久久久日本精品一区二区三区 | 91chinesexxx | 亚洲国产精品成人av | 91成人区 | 久久久福利视频 | 天天操综合 | 天天曰夜夜操 | 久久精美视频 | 精品欧美一区二区精品久久 | 精品国产欧美一区二区 | 在线观看免费色 | www.香蕉视频 | 成人在线免费视频 | 免费看的黄色网 | 亚州精品成人 | 国产精品一区二区三区免费看 | 日韩久久一区 | 国产最顶级的黄色片在线免费观看 | 欧美一区二区三区在线视频观看 | 国产又黄又猛又粗 | 久草9视频| 就要干b | 夜夜夜 | 在线观看福利网站 | 国产精品人人做人人爽人人添 | 国产精品美女久久久久久久网站 | 国产精品视频一二三 | 91传媒激情理伦片 | 国产精品欧美精品 | 91精品啪在线观看国产线免费 | 在线播放一区 | 国产精品video爽爽爽爽 | 九九精品无码 | 99视频在线看| 精品999| 国产精品久久亚洲 | 国产精品午夜在线观看 | 日韩av影视在线观看 | 在线91视频 | 天天爽夜夜爽人人爽一区二区 | www.久久com| 久久久久久久久久久久国产精品 | 欧美性黑人 | 五月婷婷久久综合 | 亚洲午夜激情网 | 中文字幕av最新更新 | 在线观看的a站 | 欧美日韩在线视频一区 | 国产做aⅴ在线视频播放 | 黄色网在线播放 | 亚洲欧美日韩国产一区二区三区 | 在线观看网站黄 | 夜夜躁狠狠燥 | 99在线观看视频 | 国产美女精彩久久 | 久久97久久 | 在线观看一区 | 久久午夜鲁丝片 | 免费午夜视频在线观看 | 欧美成人亚洲成人 | 久久精品视频网站 | 国产一二三四在线视频 | 欧美色久 | 国产a级精品| 久久久久久久久久久久久久av | 中文字幕免费看 | 玖玖视频精品 | 国产精品免费久久久久 | 亚洲成人精品 | 9999在线观看| 国产一线二线三线在线观看 | 高清一区二区三区av | 中文字幕av在线不卡 | 黄色免费国产 | 在线观看91网站 | 最近中文字幕第一页 | 成人网页在线免费观看 | 亚洲人片在线观看 | 国产成人精品亚洲 | 91九色porny在线| 99在线观看免费视频精品观看 | 97精品久久 | 国产精品 久久 | 久久av中文字幕片 | 欧美日韩p片 | 在线观看日本韩国电影 | 99中文视频在线 | 午夜影院三级 | 国产三级香港三韩国三级 | 亚洲视频一 | 亚州精品在线视频 | 久久国产精品99久久久久久老狼 | 久草在线免费看视频 | 人人澡视频 | 97国产一区二区 | 久久久官网 | 亚洲精品国产自产拍在线观看 | 亚洲国产成人精品在线观看 | 亚洲免费精彩视频 | 色天天| 香蕉视频国产在线观看 | 一级a性色生活片久久毛片波多野 | 探花在线观看 | 97超碰中文字幕 | 婷婷狠狠操 | 欧美专区日韩专区 | 成人免费在线播放 | 色午夜| 黄色特一级片 | 国产精品免费久久久久 | 成人午夜精品福利免费 | 国产在线精品福利 | 三级黄免费看 | 成人综合婷婷国产精品久久免费 | 欧美一区二区伦理片 | 麻豆一精品传二传媒短视频 | 欧美二区三区91 | 97av视频在线观看 | 高清视频一区二区三区 | 一区二区三区四区精品视频 | 国产麻豆精品久久 | 成人国产精品一区二区 | 久久超碰99 | 国产精品婷婷 | 国产精品每日更新 | 欧美性黑人 | 精品国产一区二区三区四区在线观看 | 国产亚洲精品成人av久久ww | 日韩欧美在线国产 | 天天操天天干天天玩 | 最近中文字幕大全 | 免费黄av | 久久国产亚洲 | 亚洲激情| 成人永久视频 | 一本一道久久a久久精品蜜桃 | 99久久www| 日韩黄色在线电影 | 国产不卡视频在线播放 | 少妇精69xxtheporn | 欧美日韩亚洲国产一区 | 91高清免费在线观看 | 天天干天天操人体 | 国产无套视频 | 成人在线免费视频 | 久久国产热 | 国产精品日韩久久久久 | 热re99久久精品国产66热 | 国产一区二区三区四区在线 | 在线免费观看视频一区 | 91精品中文字幕 | 亚洲精品色婷婷 | 免费网站看v片在线a | 97视频播放 | 免费的黄色的网站 | 激情欧美丁香 | 亚洲综合在线一区二区三区 | 免费网站v | 成人精品久久久 | 久久人人爽av | 久久久国际精品 | 天天操福利视频 | 在线天堂中文www视软件 | 91在线视频免费 | 日韩在线在线 | 亚洲精品九九 | 2018亚洲男人天堂 | 亚洲va在线va天堂va偷拍 | 天天躁天天操 | 99精品视频播放 | 超碰在线最新地址 | 久久综合色综合88 | 91视频 - 114av | 国产成人精品网站 | 国产精品久久久久久久久久久久久久 | 日韩精品视频在线观看网址 | 日日骑 | 亚洲视频六区 | 激情五月视频 | 27xxoo无遮挡动态视频 | 久久精彩视频 | 日韩久久久久久久久久 | 日韩在线免费不卡 | 日本一区二区三区免费看 | 国产精品系列在线观看 | 91福利视频久久久久 | 国产69精品久久久久99尤 | 99国内精品久久久久久久 | 91精品国产99久久久久久红楼 | 五月天激情视频在线观看 | av线上免费看 | 国产伦理久久精品久久久久_ | 九九99靖品| 视频一区二区国产 | 人人爱人人做人人爽 | 99r在线 | 国产伦精品一区二区三区照片91 | 国产女人免费看a级丨片 | 国产日产欧美在线观看 | 麻豆免费观看视频 | 国产成人精品免高潮在线观看 | 91在线精品一区二区 | 久久婷婷国产色一区二区三区 | 91麻豆精品国产91久久久久久 | 久久字幕网 | 视频在线观看亚洲 | 国产无遮挡又黄又爽馒头漫画 | 欧美激情第28页 | 欧美成人tv | 香蕉影视app| 婷婷精品进入 | 毛片永久免费 | 色中色资源站 | 九九热在线免费观看 | 欧美性生活久久 | 丁香视频 | 天堂av免费 | 国产剧情亚洲 | 国产视频在线播放 | 国产一级电影在线 | 超碰在线人人爱 | av综合av | 97成人在线免费视频 | 色综合色综合色综合 | 午夜精品999| 操久| 在线观看一区二区视频 | 中文字幕色网站 | 伊人黄| 免费网站看v片在线a | 丁香婷婷色综合亚洲电影 | 午夜久久美女 | 91精品国产91 | 夜夜躁日日躁狠狠躁 | 成人91在线 | 麻花豆传媒mv在线观看 | av免费观看高清 | 美女视频黄色免费 | 成人av在线直播 | www.久久色 | 久久久久免费看 | 国产一区二区精品 | 亚洲精品日韩一区二区电影 | 特级毛片在线免费观看 | 射久久| 久久国精品 | 日韩影视大全 | 亚洲精品美女在线观看播放 | 国产一区二区在线免费播放 | 久久久免费少妇 | 国产999精品久久久 免费a网站 | av免费网站观看 | 麻豆国产精品视频 | 久草精品电影 | 一区二区三区四区不卡 | 亚洲精品乱码久久久久久蜜桃91 | 四虎在线视频 | 成人蜜桃网 | 91久久丝袜国产露脸动漫 | 久久论理 | 日韩在线观看视频一区二区三区 | 久久久国产一区二区 | 国产精品理论片在线播放 | 久久伊人婷婷 | 狠狠干成人 | 久久视频6 | 一区二区三区电影在线播 | 奇米影视777影音先锋 | 四虎在线免费 | 久久无码av一区二区三区电影网 | 精品在线观看一区二区 | 99视频精品 | 日韩av电影中文字幕在线观看 | 亚洲午夜精品久久久 | 国产在线观看高清视频 | 热久久电影 | 亚洲高清免费在线 | 国产一级精品视频 | 97精品久久人人爽人人爽 | 成年人电影毛片 | 99热精品国产一区二区在线观看 | 在线涩涩 | 天天天干 | 性色av香蕉一区二区 | av在线短片 | 黄色大片av | 成人av免费在线看 | 狠狠色丁香婷婷综合基地 | 激情一区二区三区欧美 | 亚洲精品一区二区精华 | 国产一区91 | 亚洲性xxxx| 六月色丁 | 婷婷网在线 | 中文字幕a∨在线乱码免费看 | 亚洲成人av电影在线 | 一级特黄aaa大片在线观看 | 国产精品美女www爽爽爽视频 | 亚洲精品啊啊啊 | 国产成a人亚洲精v品在线观看 | 激情动态 | 中文字幕在线观看免费高清电影 | 久久高视频 | 99精品久久精品一区二区 | 91大神电影| 91精品久久久久久久91蜜桃 | 91自拍成人 | 亚洲精品系列 | 成人一区二区三区在线 | 国产精品久久久久四虎 | 亚洲精品视频免费看 | 国产精品久久久久国产a级 激情综合中文娱乐网 | 91视频亚洲 | 黄色软件视频大全免费下载 | 国产在线观看99 | 天天插综合 | 欧美日韩精品在线播放 | 成人欧美一区二区三区在线观看 | 一区二区三区播放 | 中文字幕资源网在线观看 | 精品国产中文字幕 | 亚洲精品黄网站 | 九九色网| 91免费高清 | 国产美女精品视频免费观看 | 国产一区二区在线播放视频 | 欧美日韩xxxxx | www,黄视频 | 97超碰在线免费观看 | 高清不卡毛片 | 亚一亚二国产专区 | 亚洲精品tv久久久久久久久久 | 日本中文一区二区 | 欧美午夜精品久久久久久浪潮 | 午夜免费在线观看 | 日韩精品偷拍 | 久久久亚洲麻豆日韩精品一区三区 | 超碰人人在线观看 | 成人免费一级片 | zzijzzij日本成熟少妇 | 国产尤物在线观看 | 蜜臀久久99静品久久久久久 | 91久久久国产精品 | 中文字幕乱偷在线 | 日韩视频一二三区 | 97超碰免费在线 | 在线91视频| 91看片看淫黄大片 | 开心激情五月网 | 日韩va亚洲va欧美va久久 | 免费视频91蜜桃 | 黄色国产在线观看 | 精品欧美乱码久久久久久 | 成人理论在线观看 | 久久成人免费视频 | 久久久高清一区二区三区 | 国产在线播放不卡 | 夜夜视频欧洲 | 久久久久久99精品 | 在线影院 国内精品 | 天天操狠狠操 | 亚洲色图色| 亚洲精品在线一区二区三区 | 狠狠色狠狠色综合系列 | 国产精品免费一区二区 | 亚洲午夜精品久久久久久久久久久久 | 中文视频在线播放 | 成人av网站在线播放 | 在线免费av电影 | 亚洲天天| 久久人人插 | 一本到视频在线观看 | 中文字幕永久 | 美女黄频 | 国产69精品久久久久久久久久 | 人人爽爽人人 | 香蕉在线观看 | 日本精品一区二区三区在线观看 | 久久一区二区三区超碰国产精品 | 黄色av一区二区 | 亚洲波多野结衣 | ,午夜性刺激免费看视频 | 成人av一级片 | 天天玩天天干天天操 | 久久在线一区 | 成人在线网站观看 | 婷婷深爱激情 | 蜜臀av夜夜澡人人爽人人桃色 | 日韩av男人的天堂 | av一级黄| 亚洲自拍偷拍色图 | 九九热精品视频在线播放 | av免费看看| 国产91电影在线观看 | 九九精品无码 | 亚洲精品合集 | 成人h电影在线观看 | 久久国产区 | 日韩在线观看电影 | 国产亚洲视频中文字幕视频 | 99精品在线免费观看 | 奇米影视777四色米奇影院 | 黄色日视频 | 国产一级淫片免费看 | 亚洲激情视频在线观看 | .国产精品成人自产拍在线观看6 | 中文av免费| 9在线观看免费高清完整 | 一级久久精品 | 色综合久久久久网 | 国产 日韩 欧美 中文 在线播放 | 久久久av免费 | 在线免费观看麻豆视频 | 黄色福利视频网站 | 中文国产成人精品久久一 | 色网站国产精品 | 91精品啪啪 | 国产黄色精品网站 | 国产青青青| 在线观看黄网站 | 五月激情久久 | 91精选在线 | 日p在线观看 | 狠狠色丁香婷婷综合欧美 | 一级黄色片在线 | 欧美日韩视频一区二区三区 | 夜夜看av | 日韩欧美国产免费播放 | 有码中文在线 | 日韩av在线看 | 在线播放国产一区二区三区 | 色www永久免费 | 99久久久国产精品 | aav在线| 五月天欧美精品 | 国产一级片免费播放 | 中文字幕在线播放日韩 | 国内免费久久久久久久久久久 | 人人精久 | 成人免费视频网址 | 国产一二三四在线视频 | 久久久久久高清 | 特级毛片aaa| 久草免费看 | 国产精品亚 | 亚洲黄色免费 | 99久久久国产精品免费观看 | 丁香六月天婷婷 | 亚洲国产资源 | 亚洲精品视频国产 | 黄色av网站在线观看免费 | 四虎免费av | 91黄色小视频 | 亚洲 欧洲 国产 日本 综合 | 久久综合九色综合97_ 久久久 | 久久看片网站 | 日韩三级成人 | 五月天激情综合 | 九九热在线视频免费观看 | 一区二区三区视频 | 视频在线观看日韩 | 国产精品综合av一区二区国产馆 | 亚洲欧洲视频 | 成人资源在线观看 | 国产精品毛片一区二区 | 欧美日韩国产一区二区在线观看 | 91麻豆视频网站 | 天天综合视频在线观看 | av网站免费看 | 欧美日韩精品在线 | 亚洲国产福利视频 | 久热香蕉视频 | 日韩精品一区二区三区丰满 | 日韩精品视频网站 | 国内精品视频在线播放 | 91chinesexxx| 91精品国产麻豆 | 狠狠干.com| 国产精品久久久久久影院 | 国产美女视频免费 | 久草网视频在线观看 | 国产一区二区在线视频观看 | 在线观看视频你懂的 |