antd state使用_antd Select进阶功能 动态更新、函数防抖

一、动态更新Options

Antd Select自带的搜索功能很多时候需要结合后端的接口,输入一个关键字的时候会自动更新选择器的选项. 下面列一些注意点

基础实现

选择器选项必须和每次更新的数据挂钩, 这个值可以通过state,也可以通过props拿到

再结合循环的方法例如map遍历渲染optionsimport React, { PureComponent, Fragment } from 'react'import { Select } from 'antd'import axios from 'axios'const Option = Select.Option;export default class AntSelect extends PureComponent{

...

handleSearch = (keywords) => {        //请求后端搜索接口

axios('http://xxx.com/xxx', {

keywords,

}).then(data){            this.setState({                list: data

})

}

}

render(){        const { list } = this.state;        return(            

mode="multiple"         //多选模式                placeholder="请选择"

filterOption={false}    //关闭自动筛选                onSearch={this.handleSearch}

>

{

list.map((item, index) => (                        {item}

))

}            

)

}

...

}

上面就是一个简单的例子. 除了要动态渲染Options以外, 还需要注意设置这个属性:

filterOption={false}

如果不设置会导致即使拿到了最新的数据还是依旧显示无匹配结果

因为filterOption默认为true, 当你输入内容时候,会先在已有选项里面寻找符合项, 无论是否找到,都会重新渲染Options,这样你接口请求的数据的渲染被覆盖了, 自然看不到结果了。所以需要把它关掉!

二、函数防抖

性能优化

因为输入是属于高频js的操作, 所以我们需要使用到函数节流或者函数防抖.

这里我直接使用函数防抖插件:lodash/debounceimport debounce from 'lodash/debounce';//在constructor统一绑定事件. 和经常使用的bind(this)一样class AntSelect extends React.Component {

constructor(props) {    super(props);

this.handleSearch = debounce(this.handleSearch, 500);

}

handleSearch = (value) => {

...

}

...

}

这样你在输入数据的500ms后才会触发handleSearch函数,可以大幅度减少调取后台接口的次数!

出现加载状态

antd已经给我们封装好了加载状态的组件:.然后通过state控制其出现和消失class antdSelect extends React.Component {    constructor(props) {        super(props);

this.state = {            spinState: false,

}

}

handleSearch = (keywords) => {

...        //调用接口前清空数据, 出现加载icon

this.setState({            list: [],            spinState: true

})

//请求后端搜索接口

axios('http://xxx.com/xxx', {

keywords,

}).then(data){            this.setState({                list: data,                spinState: false

})

}

...

}

render(){        const { list, spinState } = this.state;        return(            

...

notFoundContent={spinState ?  : '暂无数据'}

onSearch={this.handleSearch}

...

>

{

list.map((item, index) => (                        {item}

))

}            

)

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
antd 是一套 React UI 组件库,提供了一系列实用的组件,同时也提供了筛选条件的组件,其,选择器组件 Select 就是我们常用的筛选条件组件之一。 如果要实现两个 Select 组件之间的联动,我们需要通过事件处理函数来实现。假设我们要实现一个城市选择器和区域选择器的联动,即根据选的城市动态加载对应的区域列表。我们可以通过以下步骤来完成: 1. 定义两个 Select 组件以及相关的 state 我们可以在父组件的 state 定义 city 和 district 两个变量,用于存储当前选的城市和区域。然后在 render 方法渲染两个 Select 组件,并将 onChange 事件绑定到对应的事件处理函数。 2. 加载城市列表数据 在组件挂载完成之后,我们需要通过 API 请求服务端获取城市列表数据,并存储到 state 。 3. 实现城市选择器的 onChange 事件处理函数 当用户选择一个城市时,我们需要根据选的城市动态加载对应的区域列表。首先,我们需要将当前选的城市存储到 state 。然后,根据选的城市,从服务端获取对应的区域列表数据,并存储到 state 。最后,清空当前选的区域,并将区域选择器的下拉框关闭。 4. 实现区域选择器的 onChange 事件处理函数 当用户选择一个区域时,我们需要将当前选的区域存储到 state 。 5. 完成渲染 最后,我们需要根据 state 存储的数据渲染 Select 组件,将城市列表渲染到城市选择器,将区域列表渲染到区域选择器。 通过以上步骤,我们就可以实现两个 Select 组件的联动。因为 antd 提供了非常友好的文档和示例代码,所以实现过程并不难。相信大家只要认真学习,都可以轻松掌握。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值