表驱动法 - 巧妙利用数组返回中文星期
Date对象有个getDay方法,它根据本地时间,返回一个具体日期中一周的第几天。返回值从0~6,分别对应周日~周六
getDay | 0 | 1 | 2 | 3 | 4 | 5 | 6 |
星期几 | 周日 | 周一 | 周二 | 周三 | 周四 | 周五 | 周六 |
用到日期相关的需求时需要将getDay返回的值转成星期几,即“这一天”是星期几?比如日历组件中选择日历后返回 “2014-12-22 周一”。
这是一段依然在线上运行的代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | /* * 根据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优化下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | /* * 根据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
1 2 3 4 5 | if (a == 1) { $.ajax(xx) } // --> (a == 1) && $.ajax(xx) |
2. ?: 替代 if/else
1 2 3 4 5 6 7 | if (a == 1) { $.ajax(xx) } else { $(yy).remove() } // --> (a == 1) ? $.ajax(xx) : $(yy).remove() |
3. 多个if/else和switch 也可以用多个“?:”替换
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | 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对象来替换试下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | /* * 根据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开始。因此用数组可以再简化下
1 2 3 4 5 6 7 8 9 10 | /* * 根据Date对象返回星期几 * @param {Date} date * @return {String} "星期三" */ function getChineseWeekByDate(date) { var numWeekDay = date.getDay(); var weekArr = [ '周日' , '周一' , '周二' , '周三' , '周四' , '周五' , '周六' ]; return weekArr[numWeekDay] || '' ; } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端