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>
<script>
  var d = new Date();
  document.write('new Date():'+d);
</script>


源代码
1. 双击选中单词 2. 三击选中整行 3. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
分别获取年/月/日
需要注意的是,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>
<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. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
示例 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>
<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. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
示例 4 :

一周的第几天

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

document.write("今天是 : "+weeks[day]);
 
</script>


源代码
1. 双击选中单词 2. 三击选中整行 3. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
示例 5 :

经历的毫秒数

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


源代码
1. 双击选中单词 2. 三击选中整行 3. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
示例 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>
<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. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
示例 7 :

练习-计算年龄

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

答案-计算年龄

edit
在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
查看本答案会花费3个积分,您目前总共有点积分。查看相同答案不会花费额外积分。 积分增加办法
查看本答案会花费3个积分,您目前总共有点积分。查看相同答案不会花费额外积分。 积分增加办法
账号未激活 账号未激活,功能受限。 请点击激活
运行效果
<script> function calc(){ var year = document.getElementById("year").value; var month = document.getElementById("month").value; var day = document.getElementById("day").value; var today=new Date(); var birthday=new Date(); birthday.setFullYear(year ); birthday.setMonth(month -1); birthday.setDate(day); var nowTime = today.getTime(); var birthTime = birthday.getTime(); console.log(nowTime); console.log(birthday); var age = (nowTime -birthTime) /(1000*60*60*24*365); age= Math.round(age); document.getElementById("age").innerHTML=age; } </script> 请输入出生年月日<br> 年份 <select id="year"> <script> for(i=1900;i<2010;i++){ document.write("<option value='"+i+"'>"+i+"</option>"); } </script> </select > 月份 <select id="month"> <script> for(i=1;i<13;i++){ document.write("<option value='"+i+"'>"+i+"</option>"); } </script> </select> 日 <select id="day"> <script> for(i=1;i<32;i++){ document.write("<option value='"+i+"'>"+i+"</option>"); } </script> </select> <br> <br> <button onclick="calc()">计算年龄</button> <br> <br> 今年<span id="age">100</span> 岁


源代码
1. 双击选中单词 2. 三击选中整行 3. CTRL+F 查找 4. F8 全屏编辑,再次点击恢复
渲染中 渲染完成
效果


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


问答区域    
2021-03-27 我的答案
镜子里的笑脸




刚出生算的是1岁,应该是虚岁吧。。。
加载中
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>计算年龄</title>
    <style>
        input{
            width:40px;
        }
    </style>
</head>
<body>
<p>请输入出生年月日</p>
<p>
    年份<select id="s1">
    <script>
        var s="",i;
        for(i=1900;i<2022;i++)
        {
            s=s+"<option>"+i+"</option><br/>";
        }
        document.write(s);
    </script>
</select>月份<select id="s2">
    <script>
        var s="",i;
        for(i=1;i<13;i++)
        {
            s=s+"<option>"+i+"</option><br/>";
        }
        document.write(s);
    </script>
</select>
    日<select id="s3">
    <script>
        var s="",i;
        for(i=1;i<32;i++)
        {
            s=s+"<option>"+i+"</option><br/>";
        }
        document.write(s);
    </script>
</select>
</p>
<button type="button" onclick="jiSuan()">计算年龄</button><br><br>
今年<span style="margin:0px 10px" id="s4"> </span>岁

<script>
    function jiSuan() {
        var n1 = Number(document.getElementById("s1").value),
            n2 = Number(document.getElementById("s2").value),
            n3 = Number(document.getElementById("s3").value);
        var d = new Date();
        var d1 = d.getFullYear(),
            d2 = d.getMonth() + 1,
            d3 = d.getDate();
        var y;
        if (n1 > d1) {
            document.getElementById("s4").innerHTML = "您还没有出生";
        } else if (n1 == d1 && n2 > d2) {
            document.getElementById("s4").innerHTML = "您还没有出生";
        } else if (n1 == d1 && n2 == d2 && n3 > d3) {
            document.getElementById("s4").innerHTML = "您还没有出生";
        } else {
            y = d1 - n1;
            if (d2 > n2) {
                y = y + 1;
            } else if (d2 == n2 && d3 >= n3) {
                y = y + 1;
            }
            document.getElementById("s4").innerHTML = y;
        }
    }
</script>
</body>
</html>

							





回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2020-12-21 练习答案
hhhzt




<!--站长我这么积极,不打算给我加多点积分嘛~--> <!DOCTYPE > <html> <head> <meta charset="utf-8"> <title>计算年龄</title> <script> function add_year(){ var select_year = document.getElementById('year'); select_year.options.length = 0; select_year.options.add(new Option('请选择出生年',0)); for(var i=1900;i<=new Date().getFullYear();i++) select_year.options.add(new Option(i,i-1899)); } function add_month(){ var select_month = document.getElementById('month'); select_month.options.length = 0; select_month.options.add(new Option('请选择出生月',0)); for(var i = 1;i<=12;i++) select_month.options.add(new Option(i,i)); } function add_day(){ var select_day = document.getElementById('day'); select_day.options.length = 0; select_day.options.add(new Option('请选择出生日',0)); for(var i = 1;i<=31;i++) select_day.options.add(new Option(i,i)); } window.onload = function(){add_year();add_month();add_day();} //初始化加载js函数 function compute(){ var year = Number(document.getElementById('year').value) + 1899; //获取选中项的索引 old = new Date().getFullYear() - year; document.getElementById('age').textContent = old; } </script> <style> p{margin: 2;} select{width: 60; background-color: ghostwhite;} </style> </head> <body> <p><strong>请输入出生 年 月 日</strong></p> <div> <strong>年份</strong> <select id = 'year' ></select> <strong>月份</strong> <select id = 'month'></select> <strong>日</strong> <select id = 'day' ></select> </div><br /> <input type = 'button' id = 'compute' onclick="compute()" value="计算年龄"/><br><br /> <strong>今年</strong> <span id = 'age'>&nbsp;</span> <strong>岁</strong> </body> </html>
加载中
<!DOCTYPE >
<html>
	<head>
		<meta charset="utf-8">
		<title>计算年龄</title>
		<script>
			function add_year(){	
				var select_year = document.getElementById('year');
				select_year.options.length = 0;
				select_year.options.add(new Option('请选择出生年',0));
				
				for(var i=1900;i<=new Date().getFullYear();i++)
					select_year.options.add(new Option(i,i-1899));
			}
			function add_month(){
				var select_month = document.getElementById('month');
				select_month.options.length = 0;
				select_month.options.add(new Option('请选择出生月',0));
				for(var i = 1;i<=12;i++)	
					select_month.options.add(new Option(i,i));
			}
			function add_day(){
				var select_day = document.getElementById('day');
				select_day.options.length = 0;
				select_day.options.add(new Option('请选择出生日',0));
				for(var i = 1;i<=31;i++)	
					select_day.options.add(new Option(i,i));
			}
			window.onload = function(){add_year();add_month();add_day();}	//初始化加载js函数
			function compute(){
				var year = Number(document.getElementById('year').value) + 1899;	//获取选中项的索引
				old = new Date().getFullYear() - year;
				document.getElementById('age').textContent = old;
			}
		</script>
		
		<style>
			p{margin: 2;}
			select{width: 60;	background-color: ghostwhite;}
		</style>
	</head>
	
	<body>
		<p><strong>请输入出生 年 月 日</strong></p>
		<div>
			<strong>年份</strong>	<select id = 'year' ></select>
			<strong>月份</strong>	<select id = 'month'></select>
			<strong>日</strong>		<select id = 'day' ></select>
		</div><br />
		<input type = 'button' id = 'compute' onclick="compute()" value="计算年龄"/><br><br />
		<strong>今年</strong>
		<span id = 'age'>&nbsp;</span>
		<strong>岁</strong>
	</body>
</html>

							





回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2020-08-26 不是啊,花了积分看答案,站长答案里面2月份也可以下拉到第31天的吗?好像不太严谨的感jio
2020-05-05 本题答案做法 欢迎大家指正
2020-03-25 option里的"'可以删除,没啥用。。。。


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

提问之前请登陆
提问已经提交成功,正在审核。 请于 我的提问 处查看提问记录,谢谢
关于 前端部分-JavaScript-日期 的提问

尽量提供截图代码异常信息,有助于分析和解决问题。 也可进本站QQ群交流: 496725845
提问尽量提供完整的代码,环境描述,越是有利于问题的重现,您的问题越能更快得到解答。
对教程中代码有疑问,请提供是哪个步骤,哪一行有疑问,这样便于快速定位问题,提高问题得到解答的速度
在已经存在的几千个提问里,有相当大的比例,是因为使用了和站长不同版本的开发环境导致的,比如 jdk, eclpise, idea, mysql,tomcat 等等软件的版本不一致。
请使用和站长一样的版本,可以节约自己大量的学习时间。 站长把教学中用的软件版本整理了,都统一放在了这里, 方便大家下载: https://how2j.cn/k/helloworld/helloworld-version/1718.html

上传截图