为了账号安全,请及时绑定邮箱和手机立即绑定

input onChange中setState问题 reactjs万分感谢

input onChange中setState问题 reactjs万分感谢

天涯尽头无女友 2019-08-14 01:06:46
由于不想一直setState,想输入停止后再去setstate,于是网上找了些方法,使用方法是用debounce我参考下面代码,如果input里面加上value,不管我怎么输,为什么最后只能输出第一个字符出来?比如我输入589632147,最后只能输出5原链接http://billqiu.github.io/2017/10/15/how-to-debounce-in-react///稍微改了下,input里面加了valueimportreact,{Component}from'react';import{debounce}from'lodash.debounce';exportdefaultclassDebounceextendsComponent{construtor(){super();this.callAjax=debounce(this.callAjax,300);}callAjax=(value)=>{console.log('value::',value);this.setState({inputValue:value})//callajax}printChange(e){e.persist();this.callAjax(e.target.value);}render(){return();}}
查看完整描述

2 回答

?
慕标琳琳

TA贡献1830条经验 获得超9个赞

importReact,{Component}from'react';
lettimeout;
exportdefaultclassDebounceextendsComponent{
constructor(props){
super(props);
this.state={
text:''
}
}
debounce=(fn,wait)=>{
if(timeout!==null)clearTimeout(timeout);
timeout=setTimeout(fn,wait);
console.log(timeout);
}
handleChange=(e)=>{
consttext=e.target.value;
this.debounce(()=>{
this.setState({
text
})
},1000);
}
render(){
return(
{this.state.text}
)
}
}
                            
查看完整回答
反对 回复 2019-08-14
  • 2 回答
  • 0 关注
  • 425 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信