element必填校驗輸入空格問題修改正則表達式、請求攔截器實現(xiàn)所有輸入框去除首尾空格(推薦)
一、element-ui,必填校驗輸入空格是可以通過校驗的?
我們可以看一下elemen-ui的源碼,
我們可以看到其實element-ui對應(yīng)el-form-item關(guān)于必填校驗的部分是采用了rules,rules.length去進行的校驗 我們需要知道的是其實空格也同樣算是一個字符。同樣的空格那么肯定是會通過校驗的,那么我們?nèi)绾稳崿F(xiàn)不讓其首尾輸入空格呢?
二、解決方案?v-model.trim修飾符?
當然我們第一個想法想到的肯定是trim這個修飾符,首先我們可以看一下官網(wǎng)
我們可以試一試,當input新增了trim后會出現(xiàn)怎樣的效果?
如果采用trim修飾符的話,確實可以實現(xiàn)功能,但是這個時候首尾都不能輸入空格就會導(dǎo)致一個問題,當我們從左到右輸入文字的時候
例如
1111 2222
我如果想寫完1111立刻再輸入幾個空格再輸入2222,這個時候如果我們采用的是trim便會遇到不能輸入的問題,我們只能11112222輸入完成之后再去講鼠標光標放置在11112222中間部分輸入空格,這樣肯定是不利于我們輸入的。
三、采用pattern,手寫正則的方式實現(xiàn)功能功能。
我們只需要在我們對應(yīng)的rules數(shù)組對象校驗中新增這樣一個正則寫法即可。
pattern: ‘[^ \x20]+’
完整寫法
loginRules: { username: [{ required: true, pattern: '[^ \x20]+', trigger: 'blur', message: '用戶名不能為空' }], password: [{ required: true, pattern: '[^ \x20]+', trigger: 'blur', message: '密碼不能為空' }], code: [{ required: true, pattern: '[^ \x20]+', trigger: 'change', message: '驗證碼不能為空' }], },
四、請求攔截器過濾所有的請求參數(shù),對應(yīng)的參數(shù)首尾空格全部去掉。
當然上方的功能保證的其實也只是校驗項 在開頭部分輸入空格會觸發(fā)校驗,但是我們在末尾輸入空格的時候,對應(yīng)的校驗則不會再觸發(fā),這個時候我們則需要在進行搭配,寫一個請求遞歸,實現(xiàn)所有請求參數(shù)的首尾去空格。
編寫遞歸函數(shù)放置到我們請求攔截器當中
/** * @description: 2021-05-14 請求參數(shù)首尾去空格 * @param {*} data * @return {*} */ function isTrim(data) { // 首先需要判斷當前的config中是否存在data值 if (data && data instanceof Object) { for (const key in data) { if (Object.hasOwnProperty.call(data, key)) { // 此處我們不要使用 let element = data[key] 注意 如果采用這種方式的話對應(yīng)trim改變的值和data[key]將不再會是一個同一個內(nèi)存地址 // 在需要判斷一下當前數(shù)據(jù)是否是數(shù)組 if (Array.isArray(data[key])) { // 就將數(shù)組放進去 data[key] = isTrim(data[key]) } else if (data[key] && data[key] instanceof Object) { // 如果對象里面套對象的話 data[key] = isTrim(data[key]) } else if (data[key] && Object.prototype.toString.call(data[key]) == '[object String]') { // 如果對象里面的數(shù)據(jù)是String的話那么就直接trim只對String進行操作 data[key] = data[key].trim() } } } return data } else if (data && Object.prototype.toString.call(data) == '[object String]') { // 如果是字符串說明是JSON.parse需要轉(zhuǎn)換 let dataObj = JSON.parse(data) // 轉(zhuǎn)成對象之后在拋出去 dataObj = isTrim(dataObj) return JSON.stringify(dataObj) } else if (data && data instanceof Array) { // 如果是數(shù)組 那就forin一下 判斷里面的數(shù)據(jù)類型 for (const key in data) { if (Object.hasOwnProperty.call(data, key)) { if ((data && data instanceof Object) || (data && data instanceof Array)) { data[key] = isTrim(data[key]) } } } return data } }
在這邊我是用的是axios來實現(xiàn)ajax請求,找到我們的請求攔截器處:
遞歸完成后得到的便是字符串去除首尾空格的效果。
到此這篇關(guān)于element必填校驗 輸入空格問題,修改正則表達式、請求攔截器,實現(xiàn)所有輸入框去除首尾空格的文章就介紹到這了,更多相關(guān)element必填校驗輸入空格內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- vue中Element-ui 輸入銀行賬號每四位加一個空格的實現(xiàn)代碼
- vue+element-ui中form輸入框無法輸入問題的解決方法
- 詳解Vue3.0中ElementPlus<input輸入框自動獲取焦點>
- element input輸入框自動獲取焦點的實現(xiàn)
- Vue ElementUI實現(xiàn):限制輸入框只能輸入正整數(shù)的問題
- Element Input輸入框的使用方法
- vue element-ui實現(xiàn)input輸入框金額數(shù)字添加千分位
- Vue?elementUI表單嵌套表格并對每行進行校驗詳解
- element表單驗證如何清除校驗提示語
- Vue Element校驗validate的實例
相關(guān)文章
網(wǎng)頁中JS函數(shù)自動執(zhí)行常用三種方法
這篇文章主要為大家詳細介紹了網(wǎng)頁中JS函數(shù)自動執(zhí)行常用三種方法,感興趣的小伙伴們可以參考一下2016-03-03動態(tài)加載dtree.js樹treeview(示例代碼)
本篇文章主要是對動態(tài)加載dtree.js樹treeview的示例代碼進行了詳細的分析介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12@ResponseBody 和 @RequestBody 注解的區(qū)別
這篇文章主要介紹了@ResponseBody 和 @RequestBody 注解的區(qū)別的相關(guān)資料,需要的朋友可以參考下2017-03-03Bootstrap警告(Alerts)的實現(xiàn)方法
這篇文章主要為大家詳細介紹了Bootstrap警告(Alerts)的實現(xiàn)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03一文讓你徹底搞清楚javascript中的require、import與export
這篇文章主要給大家介紹了關(guān)于javascript中require、import與export的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對打擊大的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2017-09-09優(yōu)化javascript的執(zhí)行效率一些方法總結(jié)
本文為大家介紹下優(yōu)化javascript的執(zhí)行效率一些方法,個人感覺還不錯,感興趣的朋友可以了解下2013-12-12深入理解JavaScript系列(46):代碼復(fù)用模式(推薦篇)詳解
這篇文章主要介紹了深入理解JavaScript系列(46):代碼復(fù)用模式(推薦篇)詳解,本文講解了原型繼承、復(fù)制所有屬性進行繼承、混合(mix-in)、借用方法等模式,需要的朋友可以參考下2015-03-03