跟我学习javascript的Date对象


Posted in Javascript onNovember 19, 2015

本篇主要介绍Date 日期和时间对象的操作。

1. 介绍

1.1 说明

Date对象,是操作日期和时间的对象。Date对象对日期和时间的操作只能通过方法。

1.2 属性

无;
Date对象对日期和时间的操作只能通过方法。

2. 构造函数

2.1 new Date() :返回当前的本地日期和时间

参数:无

返回值:

{Date} 返回一个表示本地日期和时间的Date对象。

示例:

var dt = new Date();
console.log(dt); // => 返回一个表示本地日期和时间的Date对象

2.2 new Date(milliseconds) :把毫秒数转换为Date对象

参数:

①milliseconds {int} :毫秒数;表示从'1970/01/01 00:00:00'为起点,开始叠加的毫秒数。

注意:起点的时分秒还要加上当前所在的时区,北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00'

返回值:

{Date} 返回一个叠加后的Date对象。

示例:

var dt = new Date(1000 * 60 * 1); // 前进1分钟的毫秒数
console.log(dt); // => {Date}:1970/01/01 08:01:00
dt = new Date(-1000 * 60 * 1); // 倒退1分钟的毫秒数
console.log(dt); // => {Date}:1970/01/01 07:59:00

2.3 new Date(dateStr) :把字符串转换为Date对象

参数:

①dateStr {string} :可转换为Date对象的字符串(可省略时间);字符串的格式主要有两种:

1) yyyy/MM/dd HH:mm:ss (推荐):若省略时间,返回的Date对象的时间为 00:00:00。

2) yyyy-MM-dd HH:mm:ss :若省略时间,返回的Date对象的时间为 08:00:00(加上本地时区)。若不省略时间,此字符串在IE中会转换失败!

返回值:

{Date} 返回一个转换后的Date对象。

示例:

var dt = new Date('2014/12/25'); // yyyy/MM/dd
console.log(dt); // => {Date}:2014/12/25 00:00:00
dt = new Date('2014/12/25 12:00:00'); // yyyy/MM/dd HH:mm:ss
console.log(dt); // => {Date}:2014/12/25 12:00:00

dt = new Date('2014-12-25'); // yyyy-MM-dd
console.log(dt); // => {Date}:2014-12-25 08:00:00 (加上了东8区的时区)
dt = new Date('2014-12-25 12:00:00'); // yyyy-MM-dd HH:mm:ss (注意:此转换方式在IE中会报错!)
console.log(dt); // => {Date}:2014-12-25 12:00:00

2.4 new Date(year, month, opt_day, opt_hours, opt_minutes, opt_seconds, opt_milliseconds) :把年月日、时分秒转换为Date对象

参数:

①year {int} :年份;4位数字。如:1999、2014

②month {int} :月份;2位数字。从0开始计算,0表示1月份、11表示12月份。

③opt_day {int} 可选:号; 2位数字;从1开始计算,1表示1号。

④opt_hours {int} 可选:时;2位数字;取值0~23。

⑤opt_minutes {int} 可选:分;2位数字;取值0~59。

⑥opt_seconds {int} 可选:秒;2未数字;取值0~59。

⑦opt_milliseconds {int} 可选:毫秒;取值0~999。

返回值:

{Date} 返回一个转换后的Date对象。

示例:

var dt = new Date(2014, 11); // 2014年12月(这里输入的月份数字为11)
console.log(dt); // => {Date}:2014/12/01 00:00:00
dt = new Date(2014, 11, 25); // 2014年12月25日
console.log(dt); // => {Date}:2014/12/25 00:00:00
dt = new Date(2014, 11, 25, 15, 30, 40); // 2014年12月25日 15点30分40秒
console.log(dt); // => {Date}:2014/12/25 15:30:40
dt = new Date(2014, 12, 25); // 2014年13月25日(这里输入的月份数字为12,表示第13个月,跳转到第二年的1月)
console.log(dt); // => {Date}:2015/01/25

3. 实例方法

Date对象的实例方法主要分为2种形式:本地时间和UTC时间。同一个方法,一般都会有此2种时间格式操作(方法名带UTC的,就是操作UTC时间),这里主要介绍对本地时间的操作。

3.1 get方法

  • getFullYear() :返回Date对象的年份值;4位年份。
  • getMonth() :返回Date对象的月份值。从0开始,所以真实月份=返回值+1 。
  • getDate() :返回Date对象的月份中的日期值;值的范围1~31 。
  • getHours() :返回Date对象的小时值。
  • getMinutes() :返回Date对象的分钟值。
  • getSeconds() :返回Date对象的秒数值。
  • getMilliseconds() :返回Date对象的毫秒值。
  • getDay() :返回Date对象的一周中的星期值;0为星期天,1为星期一、2为星期二,依此类推
  • getTime() :返回Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00') 。

示例:

dt.getFullYear(); // => 2014:年
dt.getMonth(); // => 11:月;实际为12月份(月份从0开始计算)
dt.getDate(); // => 25:日
dt.getHours(); // => 15:时
dt.getMinutes(); // => 30:分
dt.getSeconds(); // => 40:秒
dt.getMilliseconds(); // => 333:毫秒
dt.getDay(); // => 4:星期几的值
dt.getTime(); // => 1419492640333 :返回Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')

3.2 set方法

  • setFullYear(year, opt_month, opt_date) :设置Date对象的年份值;4位年份。
  • setMonth(month, opt_date) :设置Date对象的月份值。0表示1月,11表示12月。
  • setDate(date) :设置Date对象的月份中的日期值;值的范围1~31 。
  • setHours(hour, opt_min, opt_sec, opt_msec) :设置Date对象的小时值。
  • setMinutes(min, opt_sec, opt_msec) :设置Date对象的分钟值。
  • setSeconds(sec, opt_msec) :设置Date对象的秒数值。
  • setMilliseconds(msec) :设置Date对象的毫秒值。

示例:

var dt = new Date();
dt.setFullYear(2014); // => 2014:年
dt.setMonth(11); // => 11:月;实际为12月份(月份从0开始计算)
dt.setDate(25); // => 25:日
dt.setHours(15); // => 15:时
dt.setMinutes(30); // => 30:分
dt.setSeconds(40); // => 40:秒
dt.setMilliseconds(333); // => 333:毫秒
console.log(dt); // => 2014年12月25日 15点30分40秒 333毫秒

3.3 其他方法

  • toString() :将Date转换为一个'年月日 时分秒'字符串
  • toLocaleString() :将Date转换为一个'年月日 时分秒'的本地格式字符串
  • toDateString() :将Date转换为一个'年月日'字符串
  • toLocaleDateString() :将Date转换为一个'年月日'的本地格式字符串
  • toTimeString() :将Date转换为一个'时分秒'字符串
  • toLocaleTimeString() :将Date转换为一个'时分秒'的本地格式字符串

valueOf() :与getTime()一样, 返回Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')

示例:

var dt = new Date();
console.log(dt.toString()); // => Tue Dec 23 2014 22:56:11 GMT+0800 (中国标准时间) :将Date转换为一个'年月日 时分秒'字符串
console.log(dt.toLocaleString()); // => 2014年12月23日 下午10:56:11 :将Date转换为一个'年月日 时分秒'的本地格式字符串

console.log(dt.toDateString()); // => Tue Dec 23 2014 :将Date转换为一个'年月日'字符串
console.log(dt.toLocaleDateString()); // => 2014年12月23日 :将Date转换为一个'年月日'的本地格式字符串

console.log(dt.toTimeString()); // => 22:56:11 GMT+0800 (中国标准时间) :将Date转换为一个'时分秒'字符串
console.log(dt.toLocaleTimeString()); // => 下午10:56:11 :将Date转换为一个'时分秒'的本地格式字符串

console.log(dt.valueOf()); // => 返回Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')

4. 静态方法

4.1 Date.now()

说明:返回当前日期和时间的Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')

参数:无

返回值:

{int} :当前时间与起始时间之间的毫秒数。

示例:

console.log(Date.now()); // => 1419431519276

4.2 Date.parse(dateStr)

说明:把字符串转换为Date对象 ,然后返回此Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')

参数:

①dateStr {string} :可转换为Date对象的字符串(可省略时间);字符串的格式主要有两种:

1) yyyy/MM/dd HH:mm:ss (推荐):若省略时间,返回的Date对象的时间为 00:00:00。

2) yyyy-MM-dd HH:mm:ss :若省略时间,返回的Date对象的时间为 08:00:00(加上本地时区)。若不省略时间,此字符串在IE中返回NaN(非数字)!

返回值:

{int} 返回转换后的Date对象与起始时间之间的毫秒数。

示例:

console.log(Date.parse('2014/12/25 12:00:00')); // => 1419480000000
console.log(Date.parse('2014-12-25 12:00:00')); // => 1419480000000 (注意:此转换方式在IE中返回NaN!)

分享的两个案例:

点击查看: 《javascript获取系统当前时间的方法》

点击查看: 《javascript电商网站抢购倒计时效果实现》

以上就是本文的全部内容,希望通过这篇文章大家更加了解javascript的Date对象,大家共同进步。

Javascript 相关文章推荐
JavaScript高级程序设计 阅读笔记(十四) js继承机制的实现
Aug 14 Javascript
jquery 获取表单元素里面的值示例代码
Jul 28 Javascript
javascript loadScript异步加载脚本示例讲解
Nov 14 Javascript
JavaScript验证电子邮箱的函数
Aug 22 Javascript
angularjs中的e2e测试实例
Dec 06 Javascript
浅析Node.js实现HTTP文件下载
Aug 05 Javascript
jQuery实现微信长按识别二维码功能
Aug 26 Javascript
Vue.js系列之项目结构说明(2)
Jan 03 Javascript
vue中v-for加载本地静态图片方法
Mar 03 Javascript
详解Vue-cli webpack移动端自动化构建rem问题
Apr 07 Javascript
Vue监听数据渲染DOM完以后执行某个函数详解
Sep 11 Javascript
vue动态禁用控件绑定disable的例子
Oct 28 Javascript
跟我学习javascript的this关键字
May 28 #Javascript
jQuery 1.9.1源码分析系列(十)事件系统之绑定事件
Nov 19 #Javascript
基于Jquery代码实现手风琴菜单
Nov 19 #Javascript
跟我学习javascript的作用域与作用域链
Nov 19 #Javascript
每天一篇javascript学习小结(属性定义方法)
Nov 19 #Javascript
理解 JavaScript Scoping & Hoisting(二)
Nov 18 #Javascript
js立即执行函数: (function ( ){})( ) 与 (function ( ){}( )) 有什么区别?
Nov 18 #Javascript
You might like
中国的第一台收音机
2021/03/01 无线电
php轻松实现中英文混排字符串截取
2014/05/28 PHP
ThinkPHP中redirect用法分析
2014/12/05 PHP
54个提高PHP程序运行效率的方法
2015/07/19 PHP
thinkPHP使用pclzip打包备份mysql数据库的方法
2016/04/30 PHP
php 的多进程操作实践案例分析
2020/02/28 PHP
经典的带阴影的可拖动的浮动层
2006/06/26 Javascript
this[] 指的是什么内容 讨论
2007/03/24 Javascript
javascript 匿名函数的理解(透彻版)
2010/01/28 Javascript
javascript内存管理详细解析
2013/11/11 Javascript
js实现汉字排序的方法
2015/07/23 Javascript
JS实用技巧小结(屏蔽错误、div滚动条设置、背景图片位置等)
2016/06/16 Javascript
window.open不被拦截的简单实现代码(推荐)
2016/08/04 Javascript
关于webuploader插件使用过程遇到的小问题
2016/11/07 Javascript
使用Ajax生成的Excel文件并下载的实例
2016/11/21 Javascript
javascript函数的节流[throttle]与防抖[debounce]
2017/11/15 Javascript
详解用JS添加和删除class类名
2019/03/25 Javascript
判断JavaScript中的两个变量是否相等的操作符
2019/12/21 Javascript
vue-cli 3如何使用vue-bootstrap-datetimepicker日期插件
2021/02/20 Vue.js
Python的Django框架安装全攻略
2015/07/15 Python
python实现用户登录系统
2016/05/21 Python
浅谈python对象数据的读写权限
2016/09/12 Python
Django 限制用户访问频率的中间件的实现
2018/08/23 Python
Python文件如何引入?详解引入Python文件步骤
2018/12/10 Python
python与字符编码问题
2019/05/24 Python
Python基于template实现字符串替换
2020/11/27 Python
html5.2 dialog简介详解
2018/02/27 HTML / CSS
美国户外服装和装备购物网站:Outland USA
2020/03/22 全球购物
婚前协议书怎么写
2014/04/15 职场文书
服务承诺书范文
2014/05/19 职场文书
销售团队激励口号
2014/06/06 职场文书
庆六一文艺汇演活动方案
2014/08/26 职场文书
在校证明模板
2015/06/17 职场文书
值班管理制度范本
2015/08/06 职场文书
图解排序算法之希尔排序Java实现
2021/06/26 Java/Android
OpenCV图像变换之傅里叶变换的一些应用
2021/07/26 Python