如何讓js中的if判斷如絲般順滑詳解
前言
項(xiàng)目中的一個(gè)小需求點(diǎn),點(diǎn)擊按鈕,驗(yàn)證幾十個(gè)條件框,判斷所有條件框是否填寫(選擇)過數(shù)據(jù)(至少有一個(gè)條件判斷為真)再執(zhí)行對(duì)應(yīng)操作
判斷的條件框包含 Radio 單選框,Checkbox 多選框,Input 輸入框,InputNumber 計(jì)數(shù)器, Select 選擇器, Switch 開關(guān)等
項(xiàng)目使用的 Element 組件庫 V2.15.6
不同條件對(duì)應(yīng)的數(shù)據(jù)類型以及默認(rèn)值
- Radio 單選框 string ''
- Checkbox 多選框 array []
- Input 輸入框 string ''
- InputNumber 計(jì)數(shù)器 number 0
- Select 選擇器
- 單選 string ''
- 多選 array []
- Switch 開關(guān) boolean false
代碼實(shí)現(xiàn)
思路一
直接用 if 判斷開干,然后大概代碼如下(變量為模擬變量)
// 多條件判斷開始,如下 if (obj.radio1 || obj.checkbox1.length > 0 || obj.input1 || obj.inputNumber1 > 0 || obj.select1 || obj.select2.length > 0 || obj.switch1 || obj.radio2 || obj.checkbox2.length > 0 || obj.input2 || obj.inputNumber2 > 0 || obj.select3 || obj.select4.length > 0 || obj.switch2 ...) { // do something } else { // 條件不符,提示 this.$message({ message: '請(qǐng)選擇條件后重試', type: 'warning' }) return false }
實(shí)際項(xiàng)目場景中的變量名因?yàn)檎Z義化字符很多, if 判斷沒寫幾個(gè)就寫了很長一串, 然后寫了幾個(gè)就寫不動(dòng)了(感覺在寫一坨 shi )
能不能用更優(yōu)雅的方式實(shí)現(xiàn)呢?
思路二
把這些需要判斷的變量放到一個(gè)數(shù)組里,用 map 處理成 Boolean 類型,使用 includes 判斷數(shù)組中是否包含指定的 Boolean 值
// 多條件判斷開始,如下 const arr = [ obj.radio1, obj.checkbox1.length, obj.input1, obj.inputNumber1, obj.select1, obj.select2.length, obj.switch1, obj.radio2, obj.checkbox2.length, obj.input2, obj.inputNumber2, obj.select3, obj.select4.length, obj.switch2 ... ] const arr1 = arr.map(item => Boolean(item)) if (arr1.includes(true)) { // do something } else { // 條件不符,提示 this.$message({ message: '請(qǐng)選擇條件后重試', type: 'warning' }) return false }
好了,if 處理大量判斷用這種方式使是不是更絲滑了 ^-^
總結(jié)
到此這篇關(guān)于如何讓js中if判斷如絲般順滑的文章就介紹到這了,更多相關(guān)js中的if判斷內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
參考文檔
- developer.mozilla.org/zh-CN/docs/…
- developer.mozilla.org/zh-CN/docs/…
- developer.mozilla.org/zh-CN/docs/…
- JS如何對(duì)Iframe內(nèi)外頁面進(jìn)行操作總結(jié)
- 簡易版本JSON.stringify的實(shí)現(xiàn)及其六大特性詳解
- JSON.stringify的多種用法總結(jié)
- Vue實(shí)現(xiàn)在線預(yù)覽pdf文件功能(利用pdf.js/iframe/embed)
- JavaScript JSON.stringify()的使用總結(jié)
- 詳解如何解決使用JSON.stringify時(shí)遇到的循環(huán)引用問題
- json.stringify()與json.parse()的區(qū)別以及用處
- Selenium+BeautifulSoup+json獲取Script標(biāo)簽內(nèi)的json數(shù)據(jù)
- 關(guān)于JavaScript?中?if包含逗號(hào)表達(dá)式
相關(guān)文章
微信小程序?qū)崿F(xiàn)可長按移動(dòng)控件
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)可長按移動(dòng)控件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-10-10070823更新的一個(gè)[消息提示框]組件 兼容ie7
070823更新的一個(gè)[消息提示框]組件 兼容ie7...2007-08-08BootstrapVue選項(xiàng)卡標(biāo)題增加關(guān)閉按鈕的方法
這篇文章主要為大家詳細(xì)介紹了BootstrapVue選項(xiàng)卡標(biāo)題增加關(guān)閉按鈕的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04JavaScript動(dòng)態(tài)操作表格實(shí)例(添加,刪除行,列及單元格)
這篇文章主要是對(duì)JavaScript動(dòng)態(tài)操作表格實(shí)例(添加,刪除行,列及單元格)進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-11-11使用postMesssage()實(shí)現(xiàn)iframe跨域頁面間的信息傳遞
這篇文章主要介紹了使用postMesssage()實(shí)現(xiàn)iframe跨域頁面間的信息傳遞 的相關(guān)資料,需要的朋友可以參考下2016-03-03PixiJS學(xué)習(xí)之Sprite類的使用詳解
Sprite 直譯為 “精靈”,是游戲開發(fā)中常見的術(shù)語,就是將一個(gè)角色的多個(gè)動(dòng)作放到一個(gè)圖片里,通過裁剪局部區(qū)域得到當(dāng)前的角色狀態(tài)圖。本文主要介紹了PixiJS中Sprite類的使用,需要的可以參考一下2023-02-02JavaScript參數(shù)個(gè)數(shù)可變的函數(shù)舉例說明
JavaScript允許一個(gè)函數(shù)傳遞個(gè)數(shù)可變的參數(shù),因?yàn)橛衋rguments這個(gè)內(nèi)置對(duì)象,它一個(gè)函數(shù)傳遞的所有參數(shù)的數(shù)組2014-10-10js 顯示日期時(shí)間的實(shí)例(時(shí)間過一秒加1)
下面小編就為大家?guī)硪黄猨s 顯示日期時(shí)間的實(shí)例(時(shí)間過一秒加1)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10