亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

antd Select進階功能 動態更新、函數防抖

標簽:
React

一、动态更新Options

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

基础实现

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

再结合循环的方法例如map遍历渲染options

import 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(            <Select
                mode="multiple"         //多选模式                placeholder="请选择"
                filterOption={false}    //关闭自动筛选                onSearch={this.handleSearch}
            >
                {
                    list.map((item, index) => (                        <Option key={index} value={item}>{item}</Option>
                    ))
                }            </Select>
        )
    }
    ...
}

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

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

5bf2b79200019a3a04400113.jpg

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

二、函数防抖

性能优化

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

这里我直接使用函数防抖插件:lodash/debounce

import 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已经给我们封装好了加载状态的组件:<Spin />.然后通过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(            <Select
                ...
                notFoundContent={spinState ? <Spin /> : '暂无数据'}
                onSearch={this.handleSearch}
                ...
            >
                {
                    list.map((item, index) => (                        <Option key={index} value={item}>{item}</Option>
                    ))
                }            </Select>
        )
    }
}

原文出处:https://www.cnblogs.com/soyxiaobi/p/9984491.html  

點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消