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 :

创建日期对象

通过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 全屏编辑,再次点击恢复
渲染中 渲染完成
效果
示例 2 :

年/月/日

分别获取年/月/日
需要注意的是,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 :

时:分:秒:毫秒

分别获取时:分:秒:毫秒
运行效果
<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 :

一周的第几天

通过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 :

经历的毫秒数

获取从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 :

修改日期和时间

把日期对象设置为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 :

练习-计算年龄

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

答案-计算年龄

在查看答案前,尽量先自己完成,碰到问题再来查看答案,收获会更多
运行效果
<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公众号,关注后实时获知布最新的教程和优惠活动,谢谢。


问答区域    
2018-11-21 作业
加油鸭



太难了,之前不知道可以在select中嵌套<script>
torture  折磨 ;abscure a.阴暗,模糊;exterior 外部;decay 腐烂;decent 体面的;sake 缘由;
abundant 丰富的;vacant 空的;oral 口头;optics 光学;organ 器官,风琴;expel 驱逐,开除;expenditure 支出,消费;
invade 侵入,入侵;victim 牺牲品;racial 人种的;radial 根本的;hollow 空的;

<script>
function get(id){
return document.getElementById(id).value;}
function computAge(){
var todaytime=new Date().getTime();
var birthday=new Date();
var year=get("year");
var month=get("month");
var day=get("day");
birthday.setFullYear(year);
birthday.setMonth(month -1);
birthday.setDate(day);
var birthtime=birthday.getTime();

var age =Math.round( (todaytime -birthtime) /(1000*60*60*24*365));

  document.getElementById("age").innerHTML=age;}
</script>
</br>请输入出生年月日<br>
年份
<select id="year">
<script>
for(i=1900;i<2010;i++){
  document.write("<option>"+i+"</option>");
}
</script>
</select >
月份
<select id="month">
<script>
for(i=1;i<13;i++){
  document.write("<option>"+i+"</option>");
}
</script>
</select>
日
<select  id="day">
<script>
for(i=1;i<32;i++){
  document.write("<option >"+i+"</option>");
}
</script>
</select>
<br>
<br>
<button onclick="computAge()">计算年龄</button>
<br>
<br>
今年<span id="age">100</span> 岁


							






答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2018-11-03 作业
AKZ



作业
<!DOCTYPE HTML>
<html lang="en-US">
<head>
	<meta charset="UTF-8">
	<title></title>
	<style type="text/css">
		body{
			font-size:20px;
			font-weight:bold;
		}
	</style>
	<script type="text/javascript">
		function calc(){
			var year=$("year1");
			var month=$("month1");
			var day=$("day1");
			var d=new Date();
			var currYear=d.getFullYear();
			var currMon=d.getMonth()+1;
			var currDay=d.getDate();
			var a=currYear-year;
			document.getElementById("res").value="   "+a;
		}
		function $(s){
			//var z=document.getElementById(s).selectedIndex;
			var z=document.getElementById(s).options[document.getElementById(s).selectedIndex].text;
			return z;
		}
	</script>
</head>
<body>
	<p>请输入出生年月日</p>
	年份<select id="year1">
		<script type="text/javascript">
			for(var i=1900;i<=2018;i++){
				document.write("<option>"+i+"</option>");
			}
				</script>
		</select>
	月份<select id="month1">
		<script type="text/javascript">
			for(var i=1;i<=12;i++){
				document.write("<option>"+i+"</option>");
			}
				</script>
	</select>
	日<select id="day1">
		<script type="text/javascript">
			for(var i=1;i<=31;i++){
				document.write("<option>"+i+"</option>");
			}
		</script>
	</select>
	<br />
	<input type="button"value="计算年龄" onclick="calc()"/>
	<br />
	<p>今年<input type="text" style="border:0;font-size:22px" size="1" id="res"/>岁</p>
</body>
</html>

							






答案 或者 代码至少填写一项, 如果是自己有问题,请重新提问,否则站长有可能看不到





2018-10-22 站长,各位大佬们解答一下
2018-10-22 关于天数
2018-08-16 jquery写的示例7
2018-07-18 思路
2018-05-16 简答
2018-03-22 惭愧惭愧
2018-03-18 给大伙一个idea
2018-03-18 给大家一个idea
2017-09-26 如果要解决每个月最多取到几号应该怎么操作
2017-09-11 年龄计算有问题啊
2017-07-18 几个问题
2017-07-18 age 返回值是NaN
2017-04-30 获取select 下的 option 文本
2016-12-30 世界末日
2016-11-24 字符串拼接




提问之前请登陆
关于 前端部分-JavaScript-日期 的提问

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

上传截图