一、Antd-Select提供几种类型
- 最基础版只提供下拉功能的选择器
- 带搜索功能的下拉选择器
- 可多选的下拉选择器
- 可搜索、可多选、可随意输入内容的tag下拉选择器(支持自动分词)
- 多级联动下拉选择器
- 搜索远程数据下拉框
二、一些潜在用法
如果Select.Option选项的数量特别大:2k、3k...
假设请求数据时间我们都解决好了,信心满满地准备把数据填充到<Select.Option>后下班!过会你会发现有多绝望..
这下拉框加载了10s还没出来!"_blank" href="https://codepen.io/anon/pen/eygNeR" rel="external nofollow" >antd-Select加载2k条数据演示》
发现问的人倒挺多,真正解决的回答没见到几个(我还没找到..)
有的劝着放弃吧,加了那么多用户也不会看(确实如此),改做成一个搜索下拉框.稍微执拗一点的继续挣扎,终于找到了一个能优化加载速度的插件《react-select-fast-filter-options》
然后过会又发现,搜索功能肯定也需要的呀!总不能让用户翻那2000条数据.不然可能半夜还在被投诉.
带着最后一点希望,找了一下github上antd的Issues,里面给的回答倒是挺有启发的,但是还是没有正确的解决办法.《ant-design:Issues》
于是就自己设计了一个,新手代码请见谅,希望对你有帮助.
//render const { optionsData } = this.state; <Select style={{ width: 200 }} showSearch onChange={this.handleSecChange} placeholder="请输入/选择xxx" onSearch={this.handleSerach} > { optionsData.length && optionsData.map( (item, index) => ( <Select.Option key={index} value={item}>{item}</Select.Option>) ) } </Select>
//搜索Value值改变触发回调函数 handleSerach(e){ let { clusterValue } = this.state; let that = this; //类似函数节流 setTimeout(function(){ that.loadOption(clusterValue, e) },300) } loadOption(clusterValue, keyWords){ const { options } = this.props.data; //获得2k条数据 let newOptionsData = []; let arrData = options[clusterValue]; if(Object.keys(options).length){ let len; if(arrData.length > 100) len = 100; else len = arrData.length; //初始化 if(keyWords == ''){ for(var i=0;i<len;i++){ newOptionsData.push(arrData[i]) } } //用户搜索 else{ newOptionsData = []; for(var j = 0; j < arrData.length; j++){ if(arrData[j].indexOf(keyWords) != -1){ newOptionsData.push(arrData[j]); if(newOptionsData.length > 100) break; } } } } // return newOptionsData this.setState({ optionsData: newOptionsData }) }
- 在handleSearch函数添加定时是为了解决每次输入都立刻请求,导致卡顿;用户输入完成后再统一查找,虽然会导致在搜索的时候增加300ms空白期,但是比用户输入卡顿要好
- 把渲染数量控制在100条内,防止卡顿,一般用户查找一个数据,也会输入得比较完整,不可能会在100条内查找。
- 区分初始化和搜索两个不同情况,用户刚进入界面的时候,并没有关键字搜索,所以这时候要初始化前100条内容给用户,当然你也可以按照一定的条件渲染数据给用户,只要保证合理数量以内即可
- 因为我的数据是多级联动的
options:{ 'key': [xxx,xxx1,xxx2...], 'key1': [xxx,xxx1,xxx2...] }
所以我的写法是options[xxx],然后遍历相应的数组即可
当然这仅仅是一种思路,更好的实现方法有很多!希望这能成为你的方法的一个垫脚石
有时候多看看官方文档真的很有帮助.学习的不仅仅是它的方法,还有它的思路。如果遇到它的一些特殊语法(语法糖),也可以到ant-design-pro里查阅
《ant-design-pro》
使用antd UI框架中的select需要注意的一些问题
问题1:滚动跟随问题
问题描述:使用表单时,当页面过长出现滚动,select的下拉框不会跟随输入框,造成用户体验性不好
解决方法:在 Option 或Select.Option 中添加 getPopupContainer={(triggerNode) => triggerNode.parentNode},完美解决
问题2:可输入过滤选项问题
问题描述:通过输入过滤选项
解决方法:在 Option 或Select.Option 中添加 showSearch 与 optionFilterProp="children",完美解决
问题3:动态加载
问题描述: 动态分页加载option的选项,并且,滚动加载更多,可支持关键字搜索(由后端查询数据库放回数据)
解决方法::
1、当搜索框聚焦时,获取数据,如10条,关键字为空
2、将数据遍历到option选项中
3、选项的滚动,当滚动到底部时,加载下一页的数据,在option中添加方法 onPopupScroll={this.scrollMore} scrollMore函数如下
scrollMore = (e) => { e.persist(); if(this.state.scrollFlag){ //scrollFlag 节流阀,防止操作频繁没将数据完全加载 const { target } = e; if ((target.scrollTop + target.offsetHeight) > (target.scrollHeight-25)) { //当滚动到最底部25像素的时开始加载 const { Params } = this.state; var pindex = Params.pageIndex +1; if(pindex <= this.state.pageEnd){ //判断要查询的页是否已经是最后一页了 this.setState({ scrollFlag: false, Params:{...this.state.Params,pageIndex:pindex} },() => { this.getList(); //获取option的数据 }) } } } }
至此,滚动加载完成,要注意,在每次聚焦的时候,pageIndex都要先置为1,即从第一页开始查询,否则就是从先前滚动到的那一页。在获取到数据之后,即在getList函数内,要对获取到的数据进行处理,要把获取到的数据拼接在list后面,否则会造成加载更多时之前的数据不见了,并且,在pageIndex是1的时候不拼接,直接赋值。
4、在输入值时会触发option的onSearch事件,在函数里进行查询并重新复制list
此时,会发现一个问题,查询后的值不会马上出来,会等到下一次聚焦搜索框时才会出现。
解决方法:在option中加 filterOption={false}
这样就实现了条件的过滤和关键字的过滤。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 2019明达发烧碟MasterSuperiorAudiophile[WAV+CUE]
- 蔡幸娟.1993-相爱容易相处难【飞碟】【WAV+CUE】
- 陆虎.2024-是否愿意成为我的全世界【Hikoon】【FLAC分轨】
- 关淑怡.2009-ERA【星娱乐】【WAV+CUE】
- 林忆莲《关于她的爱情故事》2022新世纪MQA 24K金碟限量版[WAV+CUE]
- 张雨生1993《一天到晚游泳的鱼》台湾G字首版[WAV+CUE][1G]
- 群星《试音五大女声》[WAV+CUE][1G]
- 魔兽世界wlk武器战一键输出宏是什么 wlk武器战一键输出宏介绍
- 魔兽世界wlk狂暴战一键输出宏是什么 wlk狂暴战一键输出宏介绍
- 魔兽世界wlk恶魔术士一键输出宏是什么 wlk恶魔术士一键输出宏介绍
- 医学爱好者狂喜:UP主把医学史做成了格斗游戏!
- PS5 Pro评分解禁!准备升级入手吗?
- 我们盘点了近期火热的国产单机游戏!《琉隐神渡》等 你期待哪款?
- 2019年第12届广州影音展双碟纪念版ADMS2CD[MP3/WAV]
- 黄安《救姻缘》台首版[WAV+CUE]