最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • JavaScript设计模式实战之策略模式

    正文概述 掘金(奉旨撸码胖大海)   2020-12-30   484

    概念

    策略模式就是把用于实现同一目标的不同算法、规则封装起来,并使它们可以被相互替换的做法。

    它提供了对开放封闭原则的完美支持,可以有效避免多重条件判断语句。

    像下面这个“根据状态值获取对应文本”的函数,就有策略模式的影子。

    function getStatusText(value){
      return {
        "Y":"已完成",
        "N":"已取消",
        "C":"待确认"
      }[value]:"状态未明"
    }
    

    实践

    应用“策略模式”对表单验证的代码进行重构。

    1. 新增一个Validate类
    // 设计模式之策略模式--表单验证类
    class Validate {
      constructor () {
        this.validateFuncs = []
      }
      add (value, rule, errorMsg) {
        this.validateFuncs.push(() => {
          // 获取对应策略的处理函数
          return this._strategies[rule](value, errorMsg)
        })
      }
      check () {
        const validateFuncs = this.validateFuncs
        let result = true
        for (let i = 0, len = validateFuncs.length; i < len; i++) {
          const errorMsg = (() => validateFuncs[i]())()
          if (errorMsg) {
            this.$toast(errorMsg)
            result = false
            break
          }
        }
        return result
      }
      // 策略
      _strategies = {
        isNotEmpty (value, errorMsg) {
          const trimedValue = typeof value === 'string' ? value.trim() : value
          if (trimedValue === '' || trimedValue === 0) {
            return errorMsg
          }
        },
        isNotLessThan (value, errorMsg) {
          const [num1, num2] = value
          if (num1 < num2) {
            return errorMsg
          }
        }
      }
    }
    export default Validate
    
    1. 使用前代码
    onSubmit() {
      if (!this.payAmount) {
        this.$toast("请输入购买金额")
        return
      }
      if (this.payAmount > this.detail.baseAmt) {
        this.$toast("购买金额不能小于起存金额")
        return
      }
      ...
    }
    
    1. 使用后
    onSubmit() {
      const validate = new Validate()
      validate.add(this.payAmount, 'isNotEmpty', '请输入购买金额')
      validate.add([this.payAmount, this.detail.baseAmt], 'isNotLessThan', '购买金额不能小于起存金额')
      ...
      if (!validate.check()) {
        return
      }
    }
    

    它的优点是通过取代大段ifelse语句,提升了代码可读性;通过封装变化(校验规则),提升了代码重用性和扩展性。缺点也有,就是我们在使用前需要了解已有策略,这违反了最少知识原则,但可以接受。


    起源地下载网 » JavaScript设计模式实战之策略模式

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元