第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定

如何阻止E,e, -, +, .的輸入當(dāng)input 的type是number in React JS

標(biāo)簽:
React.JS

前言

程序员小周经过一周的加班终于可以功能提测,sei知道测试姐姐刚开始测就告诉小周,你这不行,你这些输入字段都应该限制成数字,小周一听,好办啊,改个type类型呗,卡卡改完代码,卡卡就提交啦!这时候产品哥哥跑过来跃跃欲测,我滴天,这个e是几个意思,这个+,-,.是咋个回事,留下目瞪口呆卡卡打脸滴小周,临走产品哥哥还安慰小周,没事,这个一百度就解决了= =|||

然后

小周跟这个e杠上了,不明白这个e到底是个啥身份,你又不是数字,你瞎凑什么热闹。一查目瞪口呆.jpg,e = 2.71828!好吧,看我怎么消灭你!

不出意外,如果你也是搜索input type number e的话,相信你一定能看到这个声称一句话搞定滴解决方式

<input type="number" onKeypress="return (/[\d]/.test(String.fromCharCode(event.keyCode)))">

如果你直接cope到你的react代码里面,第一步会报错告诉你onKeypress不存在,好吧,改成onKeyPress,不对,onKeyPress得赋个function,不能是string。那接着抽个方法

handleKeyPress(event) {    return (/[\d]/.test(String.fromCharCode(event.keyCode)));
}//render<input type="number" onKeypress={this.handleKeyPress}>

不出意外,这个时候你的e,+,-等等这些讨厌的字符还是存在,你找了好久,才发现event里面根本就没有keyCode,只有key,charCode,然后你又改

handleKeyPress(event) {    return (/[\d]/.test(String.fromCharCode(event.charCode)));
}//render<input type="number" onKeypress={this.handleKeyPress}>

咦,说好的一句话解决的呢!骗子,不好使!为什么呢!
仔细瞅瞅这句话,用正则验证每次输入的单个字符,即使返回false也并没有卵用啊,为了验证

<input type="number" onKeypress={false}>

哎果然,现象是一样的。
换个思路吧,其实就是想当key是e,E,+,-,.的时候阻止它的默认行为

handleKeyPress(event) {    const invalidChars = ['-', '+', 'e', '.', 'E']    if(invalidChars.indexOf(event.key) !== -1){
      event.preventDefault()
    }
}//render<input type="number" onKeypress={this.handleKeyPress}>

果然,搞定啦!



作者:MoZhou
链接:https://www.jianshu.com/p/a215bf7bb3cc


點(diǎn)擊查看更多內(nèi)容
TA 點(diǎn)贊

若覺得本文不錯(cuò),就分享一下吧!

評(píng)論

作者其他優(yōu)質(zhì)文章

正在加載中
  • 推薦
  • 評(píng)論
  • 收藏
  • 共同學(xué)習(xí),寫下你的評(píng)論
感謝您的支持,我會(huì)繼續(xù)努力的~
掃碼打賞,你說(shuō)多少就多少
贊賞金額會(huì)直接到老師賬戶
支付方式
打開微信掃一掃,即可進(jìn)行掃碼打賞哦
今天注冊(cè)有機(jī)會(huì)得

100積分直接送

付費(fèi)專欄免費(fèi)學(xué)

大額優(yōu)惠券免費(fèi)領(lǐng)

立即參與 放棄機(jī)會(huì)
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)

舉報(bào)

0/150
提交
取消