最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

javascript中Date对象的getDay方法使用指南_javascript技巧

来源:懂视网 责编:小采 时间:2020-11-27 21:30:37
文档

javascript中Date对象的getDay方法使用指南_javascript技巧

javascript中Date对象的getDay方法使用指南_javascript技巧:Date对象有个getDay方法,它根据本地时间,返回一个具体日期中一周的第几天。返回值从0~6,分别对应周日~周六 getDay 0 1 2 3 4 5 6 星期几 周日 周一 周二 周三 周四 周五 周六 用到日期相关的需求时需要将getDay返回的值转成星期几,即这一天是星期
推荐度:
导读javascript中Date对象的getDay方法使用指南_javascript技巧:Date对象有个getDay方法,它根据本地时间,返回一个具体日期中一周的第几天。返回值从0~6,分别对应周日~周六 getDay 0 1 2 3 4 5 6 星期几 周日 周一 周二 周三 周四 周五 周六 用到日期相关的需求时需要将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] || '';
}

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

javascript中Date对象的getDay方法使用指南_javascript技巧

javascript中Date对象的getDay方法使用指南_javascript技巧:Date对象有个getDay方法,它根据本地时间,返回一个具体日期中一周的第几天。返回值从0~6,分别对应周日~周六 getDay 0 1 2 3 4 5 6 星期几 周日 周一 周二 周三 周四 周五 周六 用到日期相关的需求时需要将getDay返回的值转成星期几,即这一天是星期
推荐度:
标签: 方法 js javascript
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top