这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
这篇文章主要介绍了 javascript 中 Date 对象的 getDay 方法使用以及各种优化方案,非常不错的文章,这里推荐给大家。
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] || '';
- }
来源: http://www.phperz.com/article/17/0412/273790.html