javascript日期操作详解
它是一个内置对象——而不是其它对象的属性,允许用户执行各种使用日期和时间的过程。
方法:分为得到时间方法、设置时间方法和转换时间方法
得到时间方法:
getDate() 查看Date对象并返回日期
getDay() 返回星期几
getHours() 返回小时数
getMinutes() 返回分钟数
getMonth() 返回月份值
getSeconds() 返回秒数
getTime() 返回完整的时间
getYear() 返回年份
js中的日期时间函数具体使用注意事项: 月份获取的时候会-1. 例如当前是12月份,获取的数字就是11
var date = new Date();
date.getYear(); //获取年份(2位)
date.getFullYear(); //获取完整的年份(4位,1970-)
date.getMonth(); //获取月份(0-11,0代表1月,所以在显示当前时间的时候需要date.getMonth() + 1)
date.getDate(); //获取日(1-31)
date.getDay(); //获取星期?(0-6,0代表星期天)
date.getTime(); //获取时间(从1970.1.1开始的毫秒数)
date.getHours(); //获取小时数(0-23)
date.getMinutes(); //获取分钟数(0-59)
date.getSeconds(); //获取秒数(0-59)
date.getMilliseconds(); //获取毫秒数(0-999)
date.toLocaleString(); //获取日期与时间
设置时间方法:
setDate() 改变Date对象的日期
setHours() 改变小时数
setMinutes() 改变分钟数
setMonth() 改变月份
setSeconds() 改变秒数
setTime() 改变完整的时间
setYear() 改变年份
转换时间方法:
toGMTString() 把Date对象的日期(一个数值)转变成一个GMT时间字符串,返回类似下面的值:Weds,15 June l997 14:02:02 GMT(精确的格式依赖于计算机上所运行的操作系统而变)
toLocaleString() 把Date对象的日期(一个数值)转变成一个字符串,使用所在计算机上配置使用的特定日期格式
UTC() 使用Date UTC(年、月、日、时、分、秒),以自从1970年1月1日00:00:00(其中时、分、秒是可选的)以来的毫秒数的形式返回日期
几个需要注意的地方:
最重要的一点就是考虑到多浏览器的兼容性。需要按如下格式获取日期比较好
1
2
3
4
5
6
|
var timestart = '2015-09-05' ; var timeend = '2015-09-06' ; var time1 = (timestart+ ' 00:00:00' ).toString(); var time2 = (timeend+ ' 23:59:59' ).toString(); timestart = new Date(Date.parse(time1.replace(/-/g, "/" ))).getTime(); timeend = new Date(Date.parse(time2.replace(/-/g, "/" ))).getTime(); |
脚本之家小编为大家提供一个刚写的,在某一个时间段才显示的广告代码
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<script type= "text/javascript" > var timestart = '2015-09-05' ; var timeend = '2015-09-06' ; var time1 = (timestart+ ' 16:00:00' ).toString(); var time2 = (timeend+ ' 16:00:00' ).toString(); timestart = new Date(Date.parse(time1.replace(/-/g, "/" ))).getTime(); timeend = new Date(Date.parse(time2.replace(/-/g, "/" ))).getTime(); var nowtime= new Date().getTime(); if (nowtime>timestart && nowtime<timeend) { document.write( "广告" ); } </script> |
1、得到日期和年和设置日期和年时间,其中很怪的问题就是不能对月份进行设置(比较的怪):
1
2
3
4
5
6
7
8
|
<script language= "javascript" > d = new Date(); alert(d.toLocaleString()); d.setDate(25); alert(d.toLocaleString()); d.setYear(2000); alert(d.toLocaleString()); </script> |
2、获得年的时候最好用getFullYear()方法来做
3、由于针对月份,JS是从0开始的,因此需要对月份进行操作时要加1
下面是几个关于时间的经典而且经常会用到的例子,希望对大家会有提高的。谢谢继续关注该帖子。。。
1、将2005-8-5转换成2005-08-05格式
1
2
3
4
|
<script language= "javascript" > var strDate = '2005-8-5' ; window.alert(strDate.replace(/\b(\w)\b/g, '0$1' )); </script> |
2、得到间隔天数
1
2
3
4
5
|
<script type= "text/javascript" > <!-- alert( "间隔天数为:" +( new Date( '2005/8/15' )- new Date( '2003/9/18' ))/1000/60/60/24+ "天" ) //--> </script> |
3、得到间隔时间
1
2
3
4
5
6
7
8
9
|
<script> var d1= new Date( "2004/09/16 20:08:00" ); var d2= new Date( "2004/09/16 10:18:03" ); var d3=d1-d2; var h=Math.floor(d3/3600000); var m=Math.floor((d3-h*3600000)/60000); var s=(d3-h*3600000-m*60000)/1000; alert( "相差" +h+ "小时" +m+ "分" +s+ "秒" ); </script> |
4、得到今天的日期
1
2
3
4
|
<script language= "javascript" > d = new Date(); alert(d.getFullYear()+ "年" +(d.getMonth()+1)+ "月" +d.getDate()+ "日" ); </script> |
6、数字日期转汉字
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<html> <head> <title> New Document </title> </head> <body> <script language=javascript> Date.prototype.getRead = function () { var values = new Array( "零" , "一" , "二" , "三" , "四" , "五" , "六" , "七" , "八" , "九" ); var returnValue, temp; returnValue = this .getYear()+ "年" ; temp = ( this .getMonth()+1)+ "月" + this .getDate()+ "日" ; temp = temp.replace(/(\d)(\d)/g, "$1十$2" ).replace(/1十/g, "十" ).replace(/十0/g, "十" ); returnValue += temp; returnValue = returnValue.replace(/\d/g, function (sts){ return values[parseInt(sts)]}); return returnValue; } var t= new Date(); document.write(t.getRead()); </script> </body> </html> |
7、得到前N天或后N天的日期
方法一:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<script type= "text/javascript" > function showdate(n) { var uom = new Date( new Date()-0+n*86400000); uom = uom.getFullYear() + "-" + (uom.getMonth()+1) + "-" + uom.getDate(); return uom; } window.alert( "今天是:" +showdate(0)); window.alert( "昨天是:" +showdate(-1)); window.alert( "明天是:" +showdate(1)); window.alert( "10天前是:" +showdate(-10)); window.alert( "5天后是:" +showdate(5)); </script> |
方法二:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
<script type= "text/javascript" > function showdate(n) { var uom = new Date(); uom.setDate(uom.getDate()+n); uom = uom.getFullYear() + "-" + (uom.getMonth()+1) + "-" + uom.getDate(); return uom; } window.alert( "今天是:" +showdate(0)); window.alert( "昨天是:" +showdate(-1)); window.alert( "明天是:" +showdate(1)); window.alert( "10天前是:" +showdate(-10)); window.alert( "5天后是:" +showdate(5)); </script> |
方法三(不好意思,这个用vsscript做的,仅作为学习使用,不建议网页中使用,毕竟 IE only):
1
2
3
4
5
6
7
8
9
10
|
<script language= "vbscript" > function showdate(n) showdate=dateadd( "d" ,date(),n) end function msgbox "今天是:" &showdate( 0 ) msgbox "昨天是:" &showdate( -1 ) msgbox "明天是:" &showdate( 1 ) msgbox "十天前是:" &showdate( -10 ) msgbox "五天后是:" &showdate( 5 ) </script> |
方法四:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
<script language= "Javascript" > Date.prototype.getDays= function (){ var _newDate= new Date(); _newDate.setMonth(_newDate.getMonth()+1); _newDate.setDate(0); $_days=_newDate.getDate(); delete _newDate; return $_days; } function showdate(n) { var uom = new Date(); uom.setDate(uom.getDate()+n); uom = uom.getFullYear() + "-" + (uom.getMonth()+1) + "-" + uom.getDate()+ "\n星期" +( '天一二三四五六' .charAt(uom.getDay()))+ "\n本月有" + uom.getDays()+ "天" ; return uom; } window.alert( "今天是:" +showdate(0)); window.alert( "昨天是:" +showdate(-1)); window.alert( "明天是:" +showdate(1)); window.alert( "10天前是:" +showdate(-10)); window.alert( "5天后是:" +showdate(5)); </script> |
javascript日期操作详解的更多相关文章
- 【转】javascript日期操作详解(脚本之家整理)
时间对象是一个我们经常要用到的对象,无论是做时间输出.时间判断等操作时都与这个对象离不开.除开JavaScript中的时间对象外,在VbScript中也有许多的时间对象,而且非常好用.下面还是按照我们 ...
- JAVA8之日期操作详解
package org.date; import java.time.DayOfWeek; import java.time.LocalDate; import java.time.Month; im ...
- javascript dom 操作详解 js加强
js加强操作实现代码. 1 .文档里的每个节点都有属性 nodeName . nodeValue . nodeType nodeName 文本节点的的节点名是 #text , nodeName 是只读 ...
- JavaScript(2)---DOM详解
JavaScript(2)---DOM详解 一.DOM概念 什么是DOM DOM全称为文本对象模型(Document Object Model),它定义了所有HTML元素的对象和属性,以及访问他们的方 ...
- MongoDB各种查询操作详解
这篇文章主要介绍了MongoDB各种查询操作详解,包括比较查询.关联查询.数组查询等,需要的朋友可以参考下 一.find操作 MongoDB中使用find来进行查询,通过指定find的第一个参数可 ...
- 从mixin到new和prototype:Javascript原型机制详解
从mixin到new和prototype:Javascript原型机制详解 这是一篇markdown格式的文章,更好的阅读体验请访问我的github,移动端请访问我的博客 继承是为了实现方法的复用 ...
- [Android新手区] SQLite 操作详解--SQL语法
该文章完全摘自转自:北大青鸟[Android新手区] SQLite 操作详解--SQL语法 :http://home.bdqn.cn/thread-49363-1-1.html SQLite库可以解 ...
- MySQL 操作详解
MySQL 操作详解 一.实验简介 本节实验中学习并实践 MySQL 上创建数据库.创建表.查找信息等详细的语法及参数使用方法. 二.创建并使用数据库 1. 创建并选择数据库 使用SHOW语句找出服务 ...
- JavaScript运行机制详解
JavaScript运行机制详解 var test = function(){ alert("test"); } var test2 = function(){ alert(& ...
随机推荐
- Qt编写的RTSP播放器+视频监控(android版本)
之前写过vlc版本,ffmpeg版本,也在linux上和嵌入式linux上跑过视频监控,这次想直接用ffmpeg的库写个android版本,qt+ffmpeg+android直接用之前的qt+ffmp ...
- Elasticsearch学习之深入搜索四 --- cross-fields搜索
1. cross-fields搜索 一个唯一标识,跨了多个field.比如一个人,标识,是姓名:一个建筑,它的标识是地址.姓名可以散落在多个field中,比如first_name和last_name中 ...
- GlusterFS六大卷模式說明
GlusterFS六大卷說明 第一,分佈卷 在分布式卷文件被随机地分布在整个砖的体积.使用分布式卷,你需要扩展存储,冗余是重要或提供其他硬件/软件层.(簡介:分布式卷,文件通过hash算法随机的分 ...
- mysql语句性能分析案例
写法不一样而功能完全相同的两条 SQL 的在性能方面的差异.示例一需求:取出某个 group(假设 id 为 100)下的用户编号(id),用户昵称(nick_name).用户性别( sexualit ...
- 几种在Linux下查询外网IP的办法(转)
Curl 纯文本格式输出: curl icanhazip.com curl ifconfig.me curl curlmyip.com curl ip.appspot.com curl ipinfo. ...
- 算法学习之快速排序的C语言实现
近几天在学习简单算法,今天看了一个快速排序和堆排序,堆排序还没搞懂,还是先把快速排序搞清楚吧 教程网上一艘一大堆,这里选择一个讲的比较通俗的的一个吧: http://blog.csdn.net/mor ...
- Print or Cout an Unsigned Char Variable 打印无符号字符
在C++中,unsigned char用来表示一个字节,也就是8位大小的值,那么我们如何来打印出其值呢,用cout直接打印会乱码,我们可以通过下面两种方法来打印: cout << stat ...
- 服务端渲染(ssr)初了解
之前接触的比较多的是SPA单页面应用,前端路由渲染,对于node服务端渲染刚开始了解到,服务端渲染的话相对于SPA来说有助于SEO优化,首屏加载更快. 和之前的SPA项目不同,之前公司spa的发布部署 ...
- Docker添加镜像加速器
Docker默认pull连接镜像为国外镜像,速度较慢,注册阿里云可以生成一个镜像加速器 登录阿里云 https://cr.console.aliyun.com获取私有加速地址 修改配置文件/etc/d ...
- NLP-python 自然语言处理01
# -*- coding: utf-8 -*- """ Created on Wed Sep 6 22:21:09 2017 @author: Administrator ...