亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue項目中如何實現設置input輸入框只能輸入正數

發布時間:2020-11-09 16:53:16 來源:億速云 閱讀:2334 作者:Leah 欄目:開發技術

vue項目中如何實現設置input輸入框只能輸入正數?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

在某些項目中 input 框只能輸入數字,可以用以下辦法:

先在標簽上綁定上 @input 事件來監聽標簽的值變化,通過正則來改變輸入的值。

 <input
  class="keep_input"
  v-number-only
  
  v-model="scope.row.fileOrder"
  @input="scope.row.fileOrder = Number($event.target.value.replace(/\D+/, ''))"
 />

第二部封裝個自定義指令放在標簽上!

 directives: {
  numberOnly: {
   bind: function(el) {
    el.handler = function() {
     el.value = Number(el.value.replace(/\D+/, ''))
    }
    el.addEventListener('input', el.handler)
   },
   unbind: function(el) {
    el.removeEventListener('input', el.handler)
   }
  }
 },

接下來就可以去頁面看效果了,只能輸入數字且只是正數!

附上 element 的 input 樣式代碼

 .keep_input {
  -webkit-appearance: none;
  background-color: #fff;
  background-image: none;
  border-radius: 4px;
  border: 1px solid #dcdfe6;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  color: #606266;
  display: inline-block;
  font-size: inherit;
  outline: 0;
  padding: 0 15px;
  -webkit-transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
  transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
  height: 30px;
  line-height: 30px;
  text-align: left;
 }
 .keep_input:focus {
  border-color: #54a6de;
  outline: 0;
 }

補充知識:記錄el-input type=number限制長度el-input使用

如下所示:

<el-input type="number"
 oninput="if(value.length>10)value=value.slice(0,10)"
 @keyup.enter.native="query()"
 onKeypress="return(/[\d\.]/.test(String.fromCharCode(event.keyCode)))"
 :max="99999999">
 </el-input>

oninput 是個自定義事件 在事件里面獲取輸入的數字長度,來進行判斷如果大于規定長度就進行剪切。

keyup.enter.native 是個鍵盤回車事件,當按下Enter鍵時觸發query()事件。

max為輸入框的最大值,如果input的type=number那么輸入框內是輸入不了字符的。

number框 解決輸入e的問題

主要原因是:e在數學上代表的是無理數,是一個無限不循環的小數,其值約為2.7182818284,所以在輸入e的時候,輸入框會把e當成一個數字看待。

可以采用下面的方式來避免這個BUG,在input標簽中添加如下屬性:

onKeypress=“return(/[\d.]/.test(String.fromCharCode(event.keyCode)))”

<el-input placeholder="請輸入密碼" v-model="input" :show-password="true"></el-input>

show-password 加上這個屬性輸入字符進行隱藏一般用于密碼框使用

記錄問題!

關于vue項目中如何實現設置input輸入框只能輸入正數問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

清水县| 龙胜| 梁河县| 三原县| 黄大仙区| 江达县| 佛坪县| 稷山县| 双鸭山市| 皮山县| 杭锦旗| 孟州市| 拉萨市| 东光县| 高安市| 革吉县| 云南省| 嘉黎县| 延安市| 都江堰市| 拜城县| 台北县| 吴忠市| 横山县| 凌云县| 新丰县| 阜宁县| 武川县| 探索| 蕉岭县| 光山县| 长治县| 天峻县| 桂阳县| 塘沽区| 青海省| 新宁县| 东海县| 保亭| 调兵山市| 安龙县|