zoukankan      html  css  js  c++  java
  • 表驱动法

    Date对象有个getDay方法,它根据本地时间,返回一个具体日期中一周的第几天。返回值从0~6,分别对应周日~周六

    getDay 0 1 2 3 4 5 6
    星期几 周日 周一 周二 周三 周四 周五 周六

    用到日期相关的需求时需要将getDay返回的值转成星期几,即“这一天”是星期几?比如日历组件中选择日历后返回 “2014-12-22 周一”。

    这是一段依然在线上运行的代码

    /*
     * 根据Date对象返回星期几
     *  @param {Date} date
     *  @return {String} "星期三"
     */
    function getChineseWeekByDate(date) {
        var numWeekDay = date.getDay();
        if (numWeekDay == 0) {
            return '周日';
        } else if (numWeekDay == 1) {
            return '周一';
        } else if (numWeekDay == 2) {
            return '周二';
        } else if (numWeekDay == 3) {
            return '周三';
        } else if (numWeekDay == 4) {
            return '周四';
        } else if (numWeekDay == 5) {
            return '周五';
        } else if (numWeekDay == 6) {
            return '周六';
        } else {
            return '';
        }
    }
    

    这段代码通过多个if else分支判断,返回星期几,有同学提到可以利用switch优化下

    /*
     * 根据Date对象返回星期几
     *  @param {Date} date
     *  @return {String} "星期三"
     */
    function getChineseWeekByDate(date) {
        var numWeekDay = date.getDay();
        switch (numWeekDay) {
            case 0: return '周日';
            case 1: return '周一';
            case 2: return '周二';
            case 3: return '周三';
            case 4: return '周四';
            case 5: return '周五';
            case 6: return '周六';
            default: return '';
        }
    }
    

    相比if/else,代码简且短清晰了不少。有人做过统计,代码越简短,大脑思考的时间越短。因此你会看到各种《短码之美》,《代码简洁之道》等倡导和赞美“短码”的人和书。

    代码大全》提到利用表驱动法来简化编程

    表驱动法 — 表驱动法是一种编程模式(scheme),从表里查找信息而不使用逻辑语句(if和switch)。事实上,凡是能通过逻辑语句来选择的,都可以通过查表来选择。对简单的情况而言,使用逻辑语句更为容易和直白。但随着逻辑链越来越复杂,查表法也就显得越发有吸引力。

    上面提到利用表替代逻辑语句,JS里有不少前端工程师自从了解了函数式语言的一些特性,就拼命的用表达式消灭语句。比如

    1. && 替代 单if

    if (a == 1) {
        $.ajax(xx)
    }
    // -->
    (a == 1) && $.ajax(xx) 
    

    2. ?: 替代 if/else

    if (a == 1) {
        $.ajax(xx)
    } else {
        $(yy).remove()
    }
    // -->
    (a == 1) ? $.ajax(xx) : $(yy).remove()
    

    3. 多个if/else和switch 也可以用多个“?:”替换

    if (a == 1) {
        alert(1)
    } else if (a == 2) {
        alert(2)
    } else if (a == 3) {
        alert(3)
    } else {
        alert(4)
    }
    // -->
    (a == 1) 
        ? alert(1) : (a == 2) 
        ? alert(2) : (a == 3) 
        ? alert(3) : alert(4)
    

    另外,还可以用函数递归去消灭for/while语句。开始对这些写法比较上瘾,后来发现自己看不懂了(可能还是看的少,大脑总是自然的又将这些转换成语句),最后还是习惯用语句。

    《代码大全》里说的表,我们用一个JS对象来替换试下

    /*
     * 根据Date对象返回星期几
     *  @param {Date} date
     *  @return {String} "星期三"
     */
    function getChineseWeekByDate(date) {
        var numWeekDay = date.getDay();
        var weekObj = {
            '0': '周日',
            '1': '周一',
            '2': '周二',
            '3': '周三',
            '4': '周四',
            '5': '周五',
            '6': '周六',
        };
        return weekObj[numWeekDay] ||  '';
    }
    

    相比switch,又减了不少代码,但还有0~6字样的key存在。getDay方法返回的从0开始恰好和JS数组索引一样也是从0开始。因此用数组可以再简化下

    /*
     * 根据Date对象返回星期几
     *  @param {Date} date
     *  @return {String} "星期三"
     */
    function getChineseWeekByDate(date) {
        var numWeekDay = date.getDay();
        var weekArr = ['周日', '周一','周二','周三','周四','周五','周六'];
        return weekArr[numWeekDay] ||  '';
    }
    
  • 相关阅读:
    [转]编程能力与编程年龄
    github for windows 使用
    github 改位置
    Linux下设置和查看环境变量
    Docker基础 :网络配置详解
    docker入门实战笔记
    Jenkins +Maven+Tomcat+SVN +Apache项目持续集成构建
    使用nsenter工具进入Docker容器
    Docker从入门到实战(四)
    Docker从入门到实战(三)
  • 原文地址:https://www.cnblogs.com/snandy/p/4177413.html
Copyright © 2011-2022 走看看