欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue前端el-input輸入限制輸入位數(shù)及輸入規(guī)則

 更新時間:2023年09月11日 08:47:26   作者:穆寧!  
這篇文章主要給大家介紹了關(guān)于vue前端el-input輸入限制輸入位數(shù)及輸入規(guī)則的相關(guān)資料,文中通過代碼介紹的介紹的非常詳細,對大家學(xué)習(xí)或者使用vue具有一定的參考借鑒價值,需要的朋友可以參考下

前言

前端兼容el-input輸入時,僅允許輸入負號、數(shù)字以及小數(shù)點,且限制整數(shù)位數(shù)以及小數(shù)位數(shù),且不允許輸入除第一個負號以外的其他符號

邏輯梳理

1、使用element-ui插件的el-input組件作為頁面元素,為其綁定input事件(我這里是在表格里使用slot插入的inpu元素,所以傳入?yún)?shù)使用scope傳入)

2、綁定輸入事件,傳參給工具函數(shù),等待返回值返回

3、傳入?yún)?shù)從左到右依次為:

輸入框正在輸入的值e整數(shù)部分最大輸入位數(shù)限制intMax(number類型):控制最大輸入幾位,超過此值不可繼續(xù)輸入

小數(shù)部分最大輸入位數(shù)限制dotMax(number類型):同上

輸入框綁定的對象row:用于對象綁定

綁定對象上綁定此輸入框的鍵值name:用于數(shù)據(jù)更新

說明:工具函數(shù)內(nèi)部 return ‘0’ 的內(nèi)容可以根據(jù)需求return不同數(shù)據(jù),這里return
0便于判斷后續(xù)操作是否執(zhí)行,如果輸入不合法字符,直接干掉不合法字符,不需要執(zhí)行后面邏輯了

代碼

html:

<el-input
   autofocus
   v-if="scope.row.isActive == true"
   type="text"
   class="column-remark-input"
   v-model.trim="scope.row.adjustAmount"
   placeholder="調(diào)整金額(若有)"
   @blur="numberBlur(scope)"
   @input="inputFocus($event, scope.row, scope)"
></el-input>

工具函數(shù):

/* 輸入時 */
		inputFocus(e, row, scope) {
            var num = this.inputLimit(e, 12, 2, row, 'adjustAmount')
            console.log("?? >> inputFocus >> num:", num)
		},
/* 
            限制輸入框只可以輸入數(shù)字以及負號
            且整數(shù)位最大可輸入intMax位
            小數(shù)位最大可輸入dotMax位
            name:  綁定對象鍵值
            intMax:整數(shù)最大位數(shù)
            dotMax:小數(shù)最大位數(shù)
        */
        inputLimit(num, intMax, dotMax, row, name) {
            // 類型過濾
            if(num === undefined || num === null) {
                return '0'
            }
            var next = num + ''
            /* 如果有單位 */
            /* 單位只允許是-,且在第一位 */
            /* 第一位不是-號 則過濾掉所有多余符號*/
            var hasCompany = ( next.indexOf('-') === 0 ) ? true : false
            var res = next.match(/-/g)
            if(hasCompany && res && res.length === 1) {
                /* 負號在第一位,且只有一個負號,正常流程*/
                /* 拿走第一個負號以后需,不允許有其他任何負號 */
                next = next.substring(1)
                /* 如果有小數(shù) */
                if(next.indexOf('.') !== -1) {
                    var temp = next.split('.')
                    /* 保證 整數(shù)部分、小數(shù)部分 全部沒有怪異符號在中間 */
                    var intNum = temp[0].replace(/[^0-9]/g, "") 
                    var dotNum = temp[1].replace(/[^0-9]/g, "")
                    next = intNum + '.' + dotNum
                    this.$set(row, name, next)
                }else{
                    /* 如果沒有小數(shù) */
                    next = next.replace(/[^0-9]/g, "")
                    this.$set(row, name, next)
                }
            }else{
                /* 負號不在第一位,或者有其他怪異符號 */
                if(next.indexOf('.') !== -1) {
                    /* 如果有小數(shù) */
                    var temp = next.split('.')
                    /* 保證 整數(shù)部分、小數(shù)部分 全部沒有怪異符號在中間 */
                    var intNum = temp[0].replace(/[^0-9]/g, "") 
                    var dotNum = temp[1].replace(/[^0-9]/g, "")
                    var final = (hasCompany ? '-' : '' ) + intNum + '.' + dotNum
                    this.$set(row, name, final)
                    return '0'
                }else{
                    /* 如果沒有小數(shù) */
                    var final = next.replace(/[^0-9]/g, "")
                    this.$set(row, name, final)
                    return '0' // 這里可以根據(jù)需求return不同數(shù)據(jù),這里return 0便于判斷后續(xù)操作是否執(zhí)行,如果輸入不合法字符,直接干掉不合法字符,不需要執(zhí)行后面邏輯了
                }
            }
            if(next !== '0' && Number(next)) {
                var resNum = ''
                /* 如果有小數(shù) */
                if(next.indexOf('.') !== -1) {
                    var arr = next.split('.')
                    arr[0] = arr[0].length > intMax ? arr[0].substring(0, intMax) : arr[0]
                    if(arr[1] !== '') {
                        arr[1] = arr[1].length > dotMax ? arr[1].substring(0, dotMax) : arr[1]
                        var result = arr.join('.')
                        resNum = Number(hasCompany ? ('-' + result) : result).toFixed(arr[1].length)
                    }else{
                        var result = arr.join('.')
                        resNum = hasCompany ? ('-' + result) : result
                    }
                    this.$set(row, name, resNum)
                    return resNum
                }else{
                    /* 如果沒小數(shù) 一串?dāng)?shù)字,只需要限制位數(shù)*/
                    resNum = num.length > intMax ? num.substring(0, intMax) : num
                    this.$set(row, name, resNum)
                }
                return resNum
            }
        },

總結(jié) 

到此這篇關(guān)于vue前端el-input輸入限制輸入位數(shù)及輸入規(guī)則的文章就介紹到這了,更多相關(guān)vue前端el-input輸入限制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue關(guān)于eslint空格縮進等的報錯問題及解決

    vue關(guān)于eslint空格縮進等的報錯問題及解決

    這篇文章主要介紹了vue關(guān)于eslint空格縮進等的報錯問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue實現(xiàn)自定義右擊刪除菜單的示例

    Vue實現(xiàn)自定義右擊刪除菜單的示例

    本文主要介紹了Vue實現(xiàn)自定義右擊刪除菜單的示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • vant picker+popup 自定義三級聯(lián)動案例

    vant picker+popup 自定義三級聯(lián)動案例

    這篇文章主要介紹了vant picker+popup 自定義三級聯(lián)動案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • Vue中在新窗口打開頁面及Vue-router的使用

    Vue中在新窗口打開頁面及Vue-router的使用

    這篇文章主要介紹了Vue中在新窗口打開頁面 及 Vue-router的使用,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06
  • vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決

    vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決

    這篇文章主要介紹了vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue3.0中給自己添加一個vue.config.js配置文件

    vue3.0中給自己添加一個vue.config.js配置文件

    這篇文章主要介紹了vue3.0中給自己添加一個vue.config.js配置文件方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Vue2 中使用圖片查看器 v-viewer的方法

    Vue2 中使用圖片查看器 v-viewer的方法

    文章介紹了v-viewer插件,它是一個用于Vue的圖像查看器組件,基于viewer.js插件,可以通過npm安裝,支持指令形式和Vue組件形式的用法,并提供了豐富的配置選項和事件監(jiān)聽,感興趣的朋友跟隨小編一起看看吧
    2024-12-12
  • Vue2 SSR渲染根據(jù)不同頁面修改 meta

    Vue2 SSR渲染根據(jù)不同頁面修改 meta

    本篇文章主要介紹了Vue2 SSR渲染根據(jù)不同頁面修改 meta,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • vue封裝Animate.css動畫庫的使用方式

    vue封裝Animate.css動畫庫的使用方式

    這篇文章主要介紹了vue封裝Animate.css動畫庫的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Vue Element-ui實現(xiàn)樹形控件節(jié)點添加圖標詳解

    Vue Element-ui實現(xiàn)樹形控件節(jié)點添加圖標詳解

    這篇文章主要為大家介紹了Element-ui實現(xiàn)樹形控件節(jié)點添加圖標,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11

最新評論