我有一个(yyyy-mm-dd)格式的日期字符串,如何从中获取工作日名称?
示例:
new Date()
的日期,输出将基于当前的某一天答案 0 :(得分:17)
如果在项目的某个地方包含此功能,
// Accepts a Date object or date string that is recognized by the Date.parse() method
function getDayOfWeek(date) {
var dayOfWeek = new Date(date).getDay();
return isNaN(dayOfWeek) ? null : ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'][dayOfWeek];
}
您可以在任何地方轻松使用它:
getDayOfWeek("2013-07-31")
> "Wednesday"
getDayOfWeek(new Date())
> // (will return today's day. See demo jsfiddle below...)
如果使用无效的日期字符串,则返回null。
getDayOfWeek("~invalid~");
> null
有效日期字符串基于Date.parse() method as described in the MDN JavaScript reference。
演示: http://jsfiddle.net/samliew/fo1nnsgp/
当然,如果涉及时区,您还可以使用moment.js插件,尤其是。
答案 1 :(得分:6)
使用以下代码:
var gsDayNames = [
'Sunday',
'Monday',
'Tuesday',
'Wednesday',
'Thursday',
'Friday',
'Saturday'
];
var d = new Date("2013-07-31");
var dayName = gsDayNames[d.getDay()];
//dayName will return the name of day
答案 2 :(得分:2)
这里是单线解决方案,但请先检查支持。
let current = new Date();
let today = current.toLocaleDateString('en-US',{weekday: 'long'});
console.log(today);
let today2 = new Intl.DateTimeFormat('en-US', {weekday: 'long'}).format(current);
答案 3 :(得分:-1)
如果不想编写函数,只需使用用户定义的格式代码“ NNNN”。这将在包含日期的单元格中打印星期几。如果您确实想要字符串(而不只是在电子表格中显示单词),则可以输入公式
=TEXT(A1;"NNNN")
得到一个包含工作日的字符串。