vue 限制input只能輸入正數的操作
在某些項目中 input 框只能輸入數字,可以用以下辦法:
先在標簽上綁定上 @input 事件來監聽標簽的值變化,通過正則來改變輸入的值。
<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只能輸入正數的操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。
相關文章:
1. Docker究竟是什么 為什么這么流行 它的優點和缺陷有哪些?2. idea打開多個窗口的操作方法3. IntelliJ IDEA設置編碼格式的方法4. IDEA 重新導入依賴maven 命令 reimport的方法5. 如何通過vscode運行調試javascript代碼6. Java14發布了,再也不怕NullPointerException了7. IntelliJ IDEA 2020.2正式發布,兩點多多總能助你提效8. Intellij IDEA 閱讀源碼的 4 個絕技(必看)9. IntelliJ IDEA 統一設置編碼為utf-8編碼的實現10. IntelliJ IDEA設置背景圖片的方法步驟
