跟我学习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实例教程(19) 使用HoTMetal(2)
Dec 23 Javascript
Extjs学习笔记之四 工具栏和菜单
Jan 07 Javascript
40款非常棒的jQuery 插件和制作教程(系列二)
Nov 02 Javascript
jquery 操作iframe的几种方法总结
Dec 13 Javascript
jquery幻灯片插件bxslider样式改进实例
Oct 15 Javascript
js+html5实现可在手机上玩的拼图游戏
Jul 17 Javascript
Javascript 数组去重的方法(四种)详解及实例代码
Nov 24 Javascript
vue.js全局API之nextTick全面解析
Jul 07 Javascript
利用vue + koa2 + mockjs模拟数据的方法教程
Nov 22 Javascript
React 高阶组件入门介绍
Jan 11 Javascript
vue-cli3全面配置详解
Nov 14 Javascript
Vee-validate 父组件获取子组件表单校验结果的实例代码
May 20 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
动漫定律:眯眯眼都是怪物!这些角色狠话不多~
2020/03/03 日漫
CodeIgniter php mvc框架 中国网站
2008/05/26 PHP
让CodeIgniter数据库缓存自动过期的处理的方法
2014/06/12 PHP
PHP Class SoapClient not found解决方法
2018/01/20 PHP
Javascript之旅 对象的原型链之由来
2010/08/25 Javascript
jQuery 幻灯片插件(带缩略图功能)
2011/01/24 Javascript
jQuery循环滚动展示代码 可应用到文字和图片上
2012/05/11 Javascript
JSON语法五大要素图文介绍
2012/12/04 Javascript
javascript中兼容主流浏览器的动态生成iframe方法
2014/05/05 Javascript
js调试系列 控制台命令行API使用方法
2014/06/18 Javascript
一个css与js结合的下拉菜单支持主流浏览器
2014/10/08 Javascript
Bootstrap 组件之按钮(二)
2016/05/11 Javascript
瀑布流的实现方式(原生js+jquery+css3)
2020/06/28 Javascript
详解jquery validate实现表单验证 (正则表达式)
2017/01/18 Javascript
Vue响应式添加、修改数组和对象的值
2017/03/20 Javascript
Angular 4.x 动态创建表单实例
2017/04/25 Javascript
JS实现给json数组动态赋值的方法示例
2020/03/19 Javascript
js实现可以点击收缩或张开的悬浮窗
2017/09/18 Javascript
详解webpack运行Babel教程
2018/06/13 Javascript
详解JavaScript对数组操作(添加/删除/截取/排序/倒序)
2019/04/28 Javascript
javascript实现的时间格式加8小时功能示例
2019/06/13 Javascript
localstorage实现带过期时间的缓存功能
2019/06/28 Javascript
微信小程序(订阅消息)功能
2019/10/25 Javascript
学习python (2)
2006/10/31 Python
python爬虫selenium和phantomJs使用方法解析
2019/08/08 Python
python groupby 函数 as_index详解
2019/12/16 Python
pandas分批读取大数据集教程
2020/06/06 Python
纯css3实现宠物小鸡实例代码
2018/10/08 HTML / CSS
Bitiba意大利:在线宠物商店
2020/10/31 全球购物
一套SQL笔试题
2016/08/14 面试题
2014年信息宣传工作总结
2014/12/18 职场文书
离婚代理词范文
2015/05/23 职场文书
我的生日感言
2015/08/03 职场文书
Java实现聊天机器人完善版
2021/07/04 Java/Android
python 进阶学习之python装饰器小结
2021/09/04 Python
图神经网络GNN算法
2022/05/11 Python