java getday_javascript中Date对象的getDay方法使用指南

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

getDay 0 1 2 3 4 5 6

星期几 周日 周一 周二 周三 周四 周五 周六

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

65873c0cfdfc12cb3a6b81e9b4392a77.png

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

/*

* 根据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] ||  '';

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值