how2j.cn


工具版本兼容问题
JavaScript使用Date对象表示日期


关键字 简介 示例代码
new Date
创建日期对象
示例代码
getFullYear
getMonth
getDate
年/月/日
示例代码
getHours
getMinutes
getSeconds
getMilliseconds
时:分:秒:毫秒
示例代码
getDay
一周的第几天
示例代码
getTime
经历的毫秒数
示例代码
setFullYear
setMonth
setDate
setHours
setMinutes
setSeconds
修改日期和时间
示例代码
练习-计算年龄
示例代码
答案-计算年龄
示例代码
示例 1 : 创建日期对象   
示例 2 : 年/月/日   
示例 3 : 时:分:秒:毫秒   
示例 4 : 一周的第几天   
示例 5 : 经历的毫秒数   
示例 6 : 修改日期和时间   
示例 7 : 练习-计算年龄   
示例 8 : 答案-计算年龄   

示例 1 :

创建日期对象

edit
通过new Date创建一个日期对象,这个对象就表示当前日期(现在)
运行效果
<script> var d = new Date(); document.write('new Date():'+d); </script>
1
2
3
4
<script>
  var d = new Date();
  document.write('new Date():'+d);
</script>


分别获取年/月/日
需要注意的是,getMonth()返回的月数,是基零的,0代表1月份
运行效果
<script> var d = new Date(); document.write('分别获取年月日: '); document.write(d.getFullYear()); document.write("/"); document.write(d.getMonth()+1); document.write("/"); document.write(d.getDate()); </script>
1
2
3
4
5
6
7
8
9
<script>
  var d = new Date();
  document.write('分别获取年月日: ');
  document.write(d.getFullYear());
  document.write("/");
  document.write(d.getMonth()+1);
  document.write("/");
  document.write(d.getDate());
</script>


示例 3 :

时:分:秒:毫秒

edit
分别获取时:分:秒:毫秒
运行效果
<script> var d = new Date(); document.write("分别获取时:分:秒:毫秒 "); document.write(d.getHours()); document.write(":"); document.write(d.getMinutes()); document.write(":"); document.write(d.getSeconds()); document.write(":"); document.write(d.getMilliseconds()); </script>
1
2
3
4
5
6
7
8
9
10
11
<script>
  var d = new Date();
  document.write("分别获取时:分:秒:毫秒 ");
  document.write(d.getHours());
  document.write(":");
  document.write(d.getMinutes());
  document.write(":");
  document.write(d.getSeconds());
  document.write(":");
  document.write(d.getMilliseconds());
</script>


示例 4 :

一周的第几天

edit
通过getDay()获取,今天是本周的第几天
与getMonth()一样,返回值是基0的。
运行效果
<script> var day=new Date().getDay(); //通过日期对象获取数字形式的星期几 var weeks = new Array("星期天","星期一","星期二","星期三","星期四","星期五","星期六"); document.write("今天是 : "+weeks[day]); </script>
1
2
3
4
5
6
7
<script>
var day=new Date().getDay(); //通过日期对象获取数字形式的星期几
var weeks = new Array("星期天","星期一","星期二","星期三","星期四","星期五","星期六");
 
document.write("今天是 : "+weeks[day]);
  
</script>


示例 5 :

经历的毫秒数

edit
获取从1970/1/1 08:00:00 至今的毫秒数
运行效果
<script> var time = new Date().getTime(); document.write("从1970/1/1 08:00:00 到今天的毫秒数: "+ time); </script>
1
2
3
4
<script>
var time = new Date().getTime();
document.write("从1970/1/1 08:00:00 到今天的毫秒数: "+ time);
</script>


示例 6 :

修改日期和时间

edit
把日期对象设置为2012/12/12 00:00:00
运行效果
<script> var d=new Date(); document.write("修改日期对象的值为世界末日:<br>"); d.setFullYear(2012); d.setMonth(11); //月份是基0的,所以11表示12月 d.setDate(12); d.setHours(0); d.setMinutes(0); d.setSeconds(0); document.write(d); </script>
1
2
3
4
5
6
7
8
9
10
11
12
13
<script>
var d=new Date();
document.write("修改日期对象的值为世界末日:<br>");
d.setFullYear(2012);
d.setMonth(11); //月份是基0的,所以11表示12月
d.setDate(12);
 
d.setHours(0);
d.setMinutes(0);
d.setSeconds(0);
 
document.write(d);
</script>


示例 7 :

练习-计算年龄

edit  姿势不对,事倍功半! 点击查看做练习的正确姿势
选择出生日期,计算年龄
练习-计算年龄
示例 8 :

答案-计算年龄

edit
在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
查看本答案会花费3个积分,您目前总共有点积分。查看相同答案不会花费额外积分。 积分增加办法
查看本答案会花费3个积分,您目前总共有点积分。查看相同答案不会花费额外积分。 积分增加办法
账号未激活 账号未激活,功能受限。 请点击激活


HOW2J公众号,关注后实时获知最新的教程和优惠活动,谢谢。


问答区域    
2024-07-26 Date对象的应用
虚心求学




使用了站长答案的 document.getElementById().innerHTML 方法, 向元素的内容写入特定的值。 这里 要用 getFullYear();而不是 getYear();





回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢


2024-07-26 日期对象 需要注意的细节
虚心求学

1.getDate 和 getDay 不同。 getDate 获取的是今天是一个 “月” 中的“第几天”。 而getDay 获取的是今天是一个“星期”中的“第几天”。 getDay ()方法 还需要特别注意的是,周一到周六返回的是:1-6, 而 星期天 使用getDay()返回的是0;setDay()同样。 比如 2024/7/26(星期五) : getDate()返回的是:26。 getDay()返回的是:5。 2.getMonth 返回的月份是基0的,setMonth()也一样。 比如 2024/7/26(星期五) : getMonth()返回的是:6。




1 个答案

虚心求学
答案时间:2024-07-26
还有 getYear() 方法和 getFullYear() 方法 也需要特别注意: getYear方法已被弃用。 getYear(): 这个方法返回一个基于 1900 年的年份值。 getFullYear(): 这个方法返回一个四位数的年份值。



回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢

2022-04-11 练习-计算年龄
2021-08-22 答案 , 添加了2月判断
2021-07-01 计算准确岁数


提问太多,页面渲染太慢,为了加快渲染速度,本页最多只显示几条提问。还有 34 条以前的提问,请 点击查看

提问之前请登陆
提问已经提交成功,正在审核。 请于 我的提问 处查看提问记录,谢谢