Vue自定義指令實現(xiàn) input框只允許輸入正整數(shù)、正數(shù)(包含小數(shù))的終極解決方法

我來打自己臉了!!!!...剛剛發(fā)現(xiàn)在中文輸入法下是無效的,有人能解決這個問題么

如果要求input只能輸入數(shù)字怎么做饥侵?
設(shè)置type="number" ? 那我如果想限制長度鸵赫,此時maxLength=“6” 會失效,js限制長度躏升? 太麻煩了

并且type="number" 還存在的一個問題是辩棒,當(dāng)輸入的是小數(shù)時,鼠標(biāo)懸停在input上會提示“請輸入有效值膨疏,兩個最接近的值為0和1”一睁,這對于用戶體驗來說非常差,非常容易誤導(dǎo)用戶佃却,

那就只能設(shè)置type="text"了者吁,但是設(shè)置type="text"又會導(dǎo)致input可以輸入非數(shù)字了,于是網(wǎng)上百度google找的一大堆各種通過js去控制的饲帅,比如onkeyup事件等复凳,檢測到輸入的是非數(shù)字就截取掉,替換掉灶泵,這能夠?qū)崿F(xiàn)只能輸入數(shù)字育八,但是正如標(biāo)題所說,只允許正整數(shù)和正小數(shù)赦邻,而且還存在字母e 和 輸入1.1.111.....1 這種情況,依然通過這些方法去實現(xiàn)未免太麻煩了

今天髓棋,分享一下自己實現(xiàn)只能輸入正整數(shù)和正小數(shù),一個vue指令就可以解決!
只能輸入正整數(shù)

根據(jù)keypress事件深纲,監(jiān)視鍵盤keyCode碼仲锄,結(jié)合數(shù)字正則表達(dá)式 判斷鍵入的keyCode是否是數(shù)字劲妙,如果非數(shù)字則調(diào)用preventDefault事件阻止默認(rèn)行為
代碼中的正則使得只能輸入0-9,其他所有的字符都無法輸入儒喊,簡單粗暴

Vue.directive('enterNumber', {
  inserted: function (el) {
    el.addEventListener("keypress",function(e){
      e = e || window.event;
      let charcode = typeof e.charCode == 'number' ? e.charCode : e.keyCode;
      let re = /\d/;
      if(!re.test(String.fromCharCode(charcode)) && charcode > 9 && !e.ctrlKey){
          if(e.preventDefault){
              e.preventDefault();
          }else{
              e.returnValue = false;
          }                            
      }
    });
  }
});
只能輸入正數(shù)(包含小數(shù))

這個指令是在上面指令上做的修改镣奋,即允許輸入小數(shù)點,但是如果單純的允許輸入小數(shù)點怀愧,那就會造成輸入1.1....1....1...1這種無數(shù)小數(shù)點的情況侨颈,所有這里的處理方式是如果小數(shù)點是第一次輸入則放行,但是在下次按下鍵盤上的小數(shù)點keyCode 時會對輸入的value值進(jìn)行判斷芯义,如果value值存在小數(shù)點哈垢,則調(diào)用preventDefault() 阻止事件

Vue.directive('enterNumber2', {
  inserted: function (el) {
    el.addEventListener("keypress",function(e){
      e = e || window.event;
      let charcode = typeof e.charCode == 'number' ? e.charCode : e.keyCode;
      let re = /\d/;
      if(charcode == 46){
        if(el.value.includes('.')){
          e.preventDefault();
        }
        return;
      }else if(!re.test(String.fromCharCode(charcode)) && charcode > 9 && !e.ctrlKey){
        if(e.preventDefault){
          e.preventDefault();
        }else{
            e.returnValue = false;
        }
      }
    });
  }
});
使用方法

將上訴代碼放在main.js中,然后在input框上添加自定義指令扛拨,注意自定義指令要以v-開頭耘分,并且駝峰命名要寫在小寫的形式
注:這時候的input框type只需要使用text類型就可以了,不要使用number類型绑警,不然會出現(xiàn)“請輸入有效值求泰,兩個最接近的值為0和1”

<input type="text" v-enter-number2 >
<input type="number" step="0.0000000001" v-enter-number > 
//在只允許輸入正整數(shù)的情況下,type="number" 可以防止輸入中文计盒,step="0.0000000001" 可以處理輸入小數(shù)時的“請輸入有效值渴频,兩個.....” 
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市北启,隨后出現(xiàn)的幾起案子卜朗,更是在濱河造成了極大的恐慌,老刑警劉巖咕村,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件场钉,死亡現(xiàn)場離奇詭異,居然都是意外死亡培廓,警方通過查閱死者的電腦和手機惹悄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進(jìn)店門春叫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肩钠,“玉大人,你說我怎么就攤上這事暂殖〖劢常” “怎么了?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵呛每,是天一觀的道長踩窖。 經(jīng)常有香客問我,道長晨横,這世上最難降的妖魔是什么洋腮? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任箫柳,我火速辦了婚禮,結(jié)果婚禮上啥供,老公的妹妹穿的比我還像新娘悯恍。我一直安慰自己,他們只是感情好伙狐,可當(dāng)我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布涮毫。 她就那樣靜靜地躺著,像睡著了一般贷屎。 火紅的嫁衣襯著肌膚如雪罢防。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天唉侄,我揣著相機與錄音咒吐,去河邊找鬼。 笑死属划,一個胖子當(dāng)著我的面吹牛渤滞,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播榴嗅,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼妄呕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了嗽测?” 一聲冷哼從身側(cè)響起绪励,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎唠粥,沒想到半個月后疏魏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡晤愧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年大莫,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片官份。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡只厘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出舅巷,到底是詐尸還是另有隱情羔味,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布钠右,位于F島的核電站赋元,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜搁凸,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一媚值、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧护糖,春花似錦杂腰、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至皆刺,卻和暖如春少辣,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背羡蛾。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工漓帅, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人痴怨。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓忙干,卻偏偏與公主長得像,于是被迫代替她去往敵國和親浪藻。 傳聞我的和親對象是個殘疾皇子捐迫,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,675評論 2 359

推薦閱讀更多精彩內(nèi)容

  • ¥開啟¥ 【iAPP實現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個線程,因...
    小菜c閱讀 6,444評論 0 17
  • Lua 5.1 參考手冊 by Roberto Ierusalimschy, Luiz Henrique de F...
    蘇黎九歌閱讀 13,836評論 0 38
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理爱葵,服務(wù)發(fā)現(xiàn)施戴,斷路器,智...
    卡卡羅2017閱讀 134,704評論 18 139
  • 第2章 基本語法 2.1 概述 基本句法和變量 語句 JavaScript程序的執(zhí)行單位為行(line)萌丈,也就是一...
    悟名先生閱讀 4,151評論 0 13
  • 飛花飛絮滿階頭赞哗, 少年游,幾多愁辆雾? 水闊山高肪笋,何處訴離憂。 猶記當(dāng)年春日事度迂,飛紙鷂藤乙,笑回眸。 夜涼攜影上江樓英岭, 月...
    飛魚和迷鷺閱讀 566評論 4 1