首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React-Bootstrap-TypeAhead在尝试更改已选择的选项时出现错误

React-Bootstrap-TypeAhead在尝试更改已选择的选项时出现错误
EN

Stack Overflow用户
提问于 2021-04-01 22:53:44
回答 1查看 143关注 0票数 0

所以我使用了react-bootstrap-typeahead,当我在搜索框中输入内容时,它完全可以正常工作。当我在搜索框中键入以下内容时,它会给出相关选项:

但是,当我选择其中一个选项,然后尝试重新更改文本时,它会抛出一个错误。这是我选择1个选项时的样子。

这就是它抛出的错误: TypeError:'Cannot read property 'match‘of undefined’

以下是带有Typeahead的搜索组件的状态:

代码语言:javascript
复制
 class Search extends Component {
state = {
    hcpName: [],
    hcps: [],
    searchName: '',
    isLoading: false,
    hcp_id: 101,
    searchSelectedOption: ''
}

下面是我正在使用的Typeahead:

代码语言:javascript
复制
   <div className='col-md-3'>
                    <div class="form-group">
                        <Typeahead
                            id="basic-example"
                            options={this.state.hcpName}
                            placeholder="Search by Name..."
                            emptyLabel={this.state.isLoading ?
                                <>
                                    <span>Searching...
                                        <Loader
                                            style={{ paddingLeft: '5px', display: 'inline' }}
                                            type="Circles"
                                            color="#0caf8d"
                                            height={15}
                                            width={20}
                                            radius={30}
                                        />
                                    </span>
                                </>
                                : ''}
                            isLoading={this.state.isLoading}
                            onInputChange={(searchName) => this.setState({ searchName }, () => {
                                {
                                    let nameValue = this.state.searchName;
                                    this.setState({ isLoading: true })
                                    axios.post('/get-hcp-data', {
                                        nameValue: nameValue
                                    })
                                        .then((res) => {
                                            const hcps = res.data;
                                            this.setState({ hcps: hcps, hcpName: Object.values(hcps.hcp_details_concat) })
                                            this.setState({ isLoading: false })
                                        }, (error) => {
                                            console.log(error);
                                        });
                                }
                            })}
                            onChange={(selectedOption) => {
                                console.log('selected option: ', selectedOption[0]);
                                console.log('npi id selected', selectedOption[0].replace(/(^.*\[|\].*$)/g, ''));
                                console.log('parsed npi id selected', parseInt(selectedOption[0].replace(/(^.*\[|\].*$)/g, '')[0]));
                                this.setState({hcp_id: parseInt(selectedOption[0].match(/[^[\]]+(?=])/g)[0])});
                            }}
                        />
                    </div>
                </div>

在Typeahead的'onInputChange‘内部,我基本上是在用户每次击键之后进行一个api调用。这就是为什么你可以在那里看到一个axios请求。在'onChange‘中,我提取用户选择的方括号内的数字。

正如我所提到的,当我尝试更改已经选择的选项的文本时,我会遇到一个错误。例如,假设我点击了101Anna,我在搜索栏中看到了该文本。当我再次尝试修改它时,我立即看到一个错误。可能的原因是什么?

以下是onInput更改的控制台日志:

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-04-05 17:49:46

我通过识别匹配/替换函数不能在Typeahead的onChange中使用来解决这个问题,所以我在获取api数据时直接使用了它。为此,我首先根据用户选择的内容设置状态,如下所示:

代码语言:javascript
复制
  onChange={(selectedOption) => this.setState({ searchName: selectedOption }, () => {
                                console.log('selected option: ', selectedOption);
                            })}

然后,在获取数据时,我利用searchName状态来运行替换函数。

代码语言:javascript
复制
  dataFetch = () => {
    this.setState({ receivedData: [], loading: true });
    let page_id = this.state.page_id;
    let hcp_id = parseInt(this.state.searchName[0].replace(/(^.*\[|\].*$)/g, ''));
    axios.post('/test-json', {
        page_id: page_id,
        hcp_id: hcp_id
    })
        .then((res) => {
            this.setState({ receivedData: res.data, loading: false });
            console.log('State after loading data: ', this.state);
        }, (error) => {
            this.setState({ error: true });
            console.log(error);
        });
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66906812

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档