Javascript 更优雅的处理复杂判断

业务场景:点击 查询按钮 不同的查询条件有不同查询接口。当然每个接口都有自己固定的参数形式。

用if 判断确实会让代码的核心逻辑体现的不是很突出。个人认为在处理逻辑 只需要把核心逻辑拉出来即可。然后需要过滤的数据或者判断均可用方法来进行替代,这样后面比较容易维护。

*** 核心 Map (map 键值对 值value可以是任意模式的,这样可以任意拼接成想要的)***

方式 :通过get 方法得出可能性情况
 let request_param = new URLSearchParams()

const query_url = new Map([
    ['0_0_0', {type: '0', url: '', msg: '请选择查询项..'}],
    ['0_0_1', {
      type: '1', url: '/record/search/amount', msg: '...', params_get: (value) => {
        request_param.append('start', value.startAmount)
        request_param.append('end', value.endAmount)
      }
    }],
    ['0_1_0', {
      type: '1', url: '/record/search/date', msg: '', params_get: (value) => {
        request_param.append('start', value.startDate)
        request_param.append('end', value.endDate)
      }
    }],
    ['0_1_1', {
      type: '1', url: '/record/search/date-amount', params_get: ({startDate, endDate, startAmount, endAmount}) => {
        request_param.append('startDate', startDate)
        request_param.append('endDate', endDate)
        request_param.append('startAmount', startAmount)
        request_param.append('endAmount', endAmount)
      }
    }],
    ['1_0_0', {
      type: '1', url: '/record/search/uid', params_get: ({uid}) => {
        request_param.append('uid', uid)
      }
    }],
    ['1_1_0', {type: '0', url: '', msg: '身份证只能单独查询哦 ..'}],
    ['1_0_1', {type: '0', url: '', msg: '身份证只能单独查询哦 ..'}],
  ])


  /* 判断 type 类型 */
      judge_Null () {
        let index, index1, index2, url, params = {}
        if (this.sfz_Query === '') {
          index = 0
        } else {
          index = 1
          params.uid = this.sfz_Query
        }
        if (this.time_sot.length === 0) {
          index1 = 0
        } else {
          index1 = 1
          params.startDate = this.axios_packaged.formatDate(this.time_sot[0], 'yyyy-MM-dd')
          params.endDate = this.axios_packaged.formatDate(this.time_sot[1], 'yyyy-MM-dd')
        }
        if (this.money_Query === '') {
          index2 = 0
        } else {
          index2 = 1
          params.startAmount = 0
          params.endAmount = +this.money_Query
        }
        url = `${index}_${index1}_${index2}`
        return {url: query_url.get(url), value: params}
      }
 let {url, value} = this.judge_Null()
        if (url.type === '0') {
          this.$message({
            type: 'warning',
            message: `${url.msg}`
          })
        } else {
          /* 参数 覆盖 */
          request_param = new URLSearchParams()
          let request_url = url.url
          url.params_get(value)
          request_param.append('page', '1')
          /* 暂时设置 5条 */
          request_param.append('size', '5')
          this.$axios.post(`/api${request_url}`, request_param).then((result) => {
            let {code, data} = result.data
            if (code === 200) {
              this.process_table_data(data)
            } else {
            }
          })
        }
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容