antd design Menu選單下拉回撥以及下拉選單時只能顯示一個列表,其餘關閉
我做的是一個顯示全國省市區的下拉選單:如下圖
這個下拉選單是三層巢狀的下拉選單,統計列表不能同時開啟,一次只能點開一個。點選下拉時觸發函式獲得下一層級的下拉資料。
程式碼如下:
render(){
let city=this.state.cityList.map(itemss=>(
<SubMenu
key={itemss.id}
title={<span ><Icon type="team" /><span className="nav-text">{itemss.name}</span></span>}
onTitleClick={this.getCountryList.bind(this,itemss.id,itemss.name)}
>
{
this.state.countryList.map(citem=>(
<Menu.Item key={citem.id}> <span onClick={this.checkedItem.bind(this,citem.id,citem.name)} >{citem.name}</span></Menu.Item>
))
}
</SubMenu>
));
const { startValue, endValue, endOpen } = this.state;
return(
<div className="div-body">
<div className="div-page">
<div className="div_query ">
<Layout>
<div className="" />
<Sider
collapsed={this.state.collapsed}
style={{backgroundColor:'#FFFFFF'}}
className=""
onCollapse={this.onCollapse}
openKeys={this.state.openKeys}--->根據this.state.openKeys的值去對應SubMenu的key值 從而展開此列表。
>
<Menu theme="" mode={this.state.mode}
defaultSelectedKeys={['6']}
openKeys={this.state.openKeys}
>
<SubMenu
key="全國"
title={<span><Icon type="user" /><span className="nav-text">全國</span></span>}
onTitleClick={this.getProvinceList}
>
{
this.state.provinceList.map((items,i)=>
<SubMenu
key={items.id}
title={<span ><Icon type="team" /><span className="nav-text">{items.name}</span></span>}
onTitleClick={this.getCity.bind(this,items.id,items.name,0)}--->onTitleClick---》點選觸發回撥函式
>
{city}
</SubMenu>
)
}
</SubMenu>
</Menu>
</Sider>
)
getProvinceList=()=>{
const result=fetch('/web/chargeTrend/getChargePrinceList.htm'
,{method:'GET',
credentials:'include',
}).then((res)=>{
return res.json();
}).then((data)=>{
//var ds=eval('('+data+')');
console.log('ds',data);
if(data.length>0)
{
if(this.state.openKeys[0]==="全國")
{
this.setState({
provinceList: data,
openKeys:[],
},()=>{
console.log('privince',this.state.provinceList);
})
}else{
var arrs=["全國"];
this.setState({
provinceList: data,
openKeys:arrs,
},()=>{
console.log('privince',this.state.provinceList);
})
}
}
});
}
getCity=(parentid,name)=>{
var arr=this.state.openKeys;
const result=fetch('/web/chargeTrend/getChargeCityList.htm?parentid='+parentid,
{method:'GET',
credentials:'include',
}).then((res)=>{
return res.json();
}).then((data)=>{
console.log('city',data);
if(data.length>0)
{
if(parentid===this.state.openKeys[1])
{
var arrs=["全國"];
this.setState({
cityList:data,
adCode:parentid,
sRange:name,
openKeys:arrs,
},()=>{
console.log('cityList',this.state.cityList);
console.log('city1',this.state.openKeys);
});
}else{
var arrs=["全國"];
arrs.push(parentid);
this.setState({
cityList:data,
adCode:parentid,
sRange:name,
openKeys:arrs,
},()=>{
console.log('cityList',this.state.cityList);
console.log('city1',this.state.openKeys);
});
}
}
});
}
getCountryList=(parentid,name)=>{
var arr=this.state.openKeys;
const result=fetch('/web/chargeTrend/getCountyList.htm?parentid='+parentid,
{method:'GET',
credentials:'include',
}).then((res)=>{
return res.json();
}).then((data)=>{
console.log('country',data);
if(data.length>0)
{
if(this.state.openKeys.length>=3)
{
if(parentid===this.state.openKeys[2])
{
var arrs=["全國"];
arrs.push(arr[1]);
this.setState({
countryList:data,
adCode:parentid,
sRange:name,
openKeys:arrs,
},()=>{
console.log('Country1',this.state.openKeys)
});
}else{
var arrs=["全國"];
arrs.push(arr[1]);
arrs.push(parentid);
this.setState({
countryList:data,
adCode:parentid,
sRange:name,
openKeys:arrs,
},()=>{
console.log('Country2',this.state.openKeys)
});
}
}else{
arr.push(parentid);
this.setState({
countryList:data,
adCode:parentid,
sRange:name,
openKeys:arr,
},()=>{
console.log('Country3',this.state.openKeys)
});
}
}
});
}
}
相關文章
- 滑鼠經過顯示下拉選單
- bootstrap 選單導航選單nav li滑鼠移入hover下拉顯示boot
- js css滑鼠懸停顯示下拉選單JSCSS
- HTML+CSS+JQuery實現下拉選單滑鼠懸浮顯示下拉選單,取消隱藏HTMLCSSjQuery
- 下拉選單「點選外面關閉」的終極解決方案
- win10怎麼在桌面右鍵選單新增關閉顯示器選項_win10右鍵選單新增關閉顯示器的教程Win10
- Tkinter (10) 選單部件 Menu
- vue下拉選單Vue
- 實現單擊一級選單顯示或隱藏二級選單
- vue3下拉選單點選之後緩慢展開與緩慢關閉Vue
- JavaScript實現HTML導航欄下拉選單[懸浮顯示]JavaScriptHTML
- kendoUI 多選下拉選單 kendoMultiSelectUI
- jQuery實現簡單點選隱藏和點選顯示列表的功能jQuery
- ant design模態框中使用Select元件下拉選框不顯示元件
- HTML select 下拉選單HTML
- HTML select下拉選單HTML
- jquery-滑鼠經過導航條,顯示二級下拉選單jQuery
- js物件導向封裝級聯下拉選單列表JS物件封裝
- [提問交流]新下載的onethink後臺新增一個頂級選單然後在新增二級選單,新增的二級選單不顯示
- CSS 二級下拉選單CSS
- jQuery 美化select下拉選單jQuery
- CSS二級下拉選單CSS
- 圓角select下拉選單
- 關於Spyder在高解析度顯示器下的選單圖示顯示不正確問題
- 012---表單、下拉選單和表單域
- vue元件之路之menu導航選單Vue元件
- tkinter中menu選單控制元件(十二)控制元件
- 線上直播原始碼,開發一個下拉選單元件原始碼元件
- 三種方法解決純css下拉選單滑鼠移入選單內容時選單隱藏消失的問題CSS
- 選擇select下拉選單網頁跳轉網頁
- checkbox及css實現點選下拉選單CSS
- 記一次工時系統改版(前端下拉選單懶載入與選項資料回顯)前端
- 下拉框select中指定option時觸發的選中事件,以及已知選中的值,將它顯示在下拉框中事件
- 一個CollectionView 選單View
- Selenium測試form表單之下拉選單ORM
- 鴻蒙js開發7 鴻蒙分組列表和彈出menu選單鴻蒙JS
- windows11 始終右鍵選單顯示更多選項/右鍵選單返回舊版Windows
- BootstrapBlazor實戰 Menu 導航選單使用(2)bootBlazor