zoukankan      html  css  js  c++  java
  • JS常用的设计模式(9)——策略模式

    策略模式的意义是定义一系列的算法,把它们一个个封装起来,并且使它们可相互替换。
    一个小例子就能让我们一目了然。

    回忆下jquery里的animate方法.

    $( div ).animate( {"left: 200px"}, 1000, 'linear' );  //匀速运动 
    $( div ).animate( {"left: 200px"}, 1000, 'cubic' );  //三次方的缓

    这2句代码都是让div在1000ms内往右移动200个像素. linear(匀速)和cubic(三次方缓动)就是一种策略模式的封装.

    再来一个例子. 上半年我写的dev.qplus.com, 很多页面都会有个即时验证的表单. 表单的每个成员都会有一些不同的验证规则.

    比如姓名框里面, 需要验证非空,敏感词,字符过长这几种情况。 当然是可以写3个if else来解决,不过这样写代码的扩展性和维护性可想而知。如果表单里面的元素多一点,需要校验的情况多一点,加起来写上百个if else也不是没有可能。

    所以更好的做法是把每种验证规则都用策略模式单独的封装起来。需要哪种验证的时候只需要提供这个策略的名字。就像这样:

    nameInput.addValidata({ 
       notNull: true, 
       dirtyWords: true, 
       maxLength: 30 
    }) 
    而notNull,maxLength等方法只需要统一的返回true或者false,来表示是否通过了验证。 
    validataList = { 
      notNull: function( value ){ 
         return value !== ''; 
      }, 
      maxLength: function( value, maxLen ){ 
         return value.length() > maxLen; 
      } 
    } 

    可以看到,各种验证规则很容易被修改和相互替换。如果某天产品经理建议字符过长的限制改成60个字符。那只需要0.5秒完成这次工作。

  • 相关阅读:
    Chap-6 6.1~6.3 程序装载
    X Window基础二(转)
    X Window基础一(转)
    Linux基础命令 su与sudo的区别
    Chap-4 Section 4.6 链接控制过程
    Chap-4 Section 4.5 静态库链接
    ceph的CRUSH数据分布算法介绍
    使用ffmpeg捕获USB外部摄像头视频流
    使用ffserver实现转发实时流媒体(摄像头捕获)
    内存映射文件(专门读写大文件)
  • 原文地址:https://www.cnblogs.com/jymz/p/4273906.html
Copyright © 2011-2022 走看看