表驱动法 巧妙利用数组返回中文星期 -电脑资料

电脑资料 时间:2019-01-01 我要投稿
【www.unjs.com - 电脑资料】

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

    /*

    * 根据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语句,

电脑资料

表驱动法 巧妙利用数组返回中文星期》(https://www.unjs.com)。开始对这些写法比较上瘾,后来发现自己看不懂了(可能还是看的少,大脑总是自然的又将这些转换成语句),最后还是习惯用语句。

    《代码大全》里说的表,我们用一个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] || '';

    }

最新文章