欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

解决Antd 里面的select 选择框联动触发的问题

程序员文章站 2022-03-11 14:52:25
有两个 select框,且这俩select框是关联的,触发select1,select2里面才会有值。但是现在的问题是这样的:触发select1,触发select2,再触发select1,此时sele...

有两个 select框,且这俩select框是关联的,触发select1,select2里面才会有值。

但是现在的问题是这样的:

解决Antd 里面的select 选择框联动触发的问题

触发select1,触发select2,再触发select1,此时select2里面的值变成了上次一选中的value 值,而不会被清空。

解决办法:

使用select 里面的value属性,来进行清空

<form style={{padding:'20px','boxsizing':'border-box'}}>
 <formitem label="套卷名称" {...formitemlayout}>
  <select defaultvalue={packagedpapersid} onchange={selectpackage}>
  {
   packagedpaperlist.map((item,idx)=>(
   <option value={item.packagedpapersid} key={idx}>{item.packagedpapersname}</option>
   ))
  }
  </select>
 </formitem>
 <formitem label="试卷名称" {...formitemlayout}>
  <select defaultvalue={paperid} value={paperid} onchange={(val,item)=>selectpaper(val,item)}>
  {
   paperlist.map((item,idx)=>(
   <option value={item.paperid} key={idx}>{item.papername}</option>
   ))
  }
  </select>
 </formitem>
</form>
// select1里面的判断
const selectpackage = (value) =>{
 if(paperid != '请选择名称'){
  setpaperid('请选择名称');
 }
 setpackagedpapersid(value)
 paperlistfn(value)
}

补充知识:antd rangepicker限制选择时间跨度是30天

我就废话不多说了,大家还是直接看代码吧~

const { rangepicker } = datepicker;

const [selectdate, setselectdate] = usestate(null);

 /* 控制下单时间选择范围30天 */
 const disabledtaskdate = (current) => {
 if (!current || !selectdate) return false;
 const offsetv = 2592000000;     //30天转换成ms
 const selectv = selectdate.valueof();
 const currenv = current.valueof();
 return (calcminus(currenv, offsetv) > selectv || calcadd(currenv, offsetv) < selectv) ? true : false;
 }

 /* 选择任务时间变化 */
 const ondatechange = (dates) => {
 if (!dates || !dates.length) return;
 setselectdate(dates[0]);
 }

 const ondateopenchange = () => {
 setselectdate(null);
 }
<rangepicker
 showtime={{ format: 'hh:mm:ss' }}
 disableddate={disabledtaskdate}
 oncalendarchange={ondatechange}
 onopenchange={ondateopenchange}
 />

以上这篇解决antd 里面的select 选择框联动触发的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。