• 你不知道的JavaScript--Item22 Date对象全解析


    本篇主要介绍 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()); // => 20141223日 下午10:56:11  :将Date转换为一个'年月日 时分秒'的本地格式字符串
    
    console.log(dt.toDateString()); // => Tue Dec 23 2014 :将Date转换为一个'年月日'字符串
    console.log(dt.toLocaleDateString()); // => 20141223日 :将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!)

    5. Demo 练习

    5.1、获得系统当前时间:格式为:2015年10月29日 星期四21:01:05

    <!DOCTYPE html>
    <html>
    <head>
        <title>获取时间</title>
        <script type="text/javascript">
        window.onload = function(){
            showTime();
        }
    
        function showTime(){
            var myDate = new Date();
            var year = myDate.getFullYear();
            var month = myDate.getMonth() + 1;
            var date = myDate.getDate();
            var dateArr = ["日","一",'二','三','四','五','六'];
            var day = myDate.getDay();
            var hours = myDate.getHours();
            var minutes = formatTime(myDate.getMinutes());
            var seconds = formatTime(myDate.getSeconds());
    
            var systemTime = document.getElementById("time");
            systemTime.innerHTML = " " + year + "年" + month +"月" + date + "日" + " 星期" + dateArr[day] + " " + hours + ":" +  minutes + ":" + seconds;
            setTimeout("showTime()",500);
        }
    
        //格式化时间:分秒。
        function formatTime (i){
            if(i < 10){
                i = "0" + i;
            }
            return i;
        }
    
        </script>
    </head>
    <body>
        <div id ='time'></div>
    </body>
    </html>

    2、电商网站抢购倒计时

    <!DOCTYPE html>
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>团购——限时抢</title>
    
    </head>
    
    <body>
    
    <div class="time"> <span id="LeftTime"></span></div>
    </div>
    <script>
    function FreshTime()
    {
            var endtime=new Date("2015/11/11,12:20:12");//结束时间
            var nowtime = new Date();//当前时间
            var lefttime=parseInt((endtime.getTime()-nowtime.getTime())/1000); 
            d=parseInt(lefttime/3600/24);
            h=parseInt((lefttime/3600)%24);
            m=parseInt((lefttime/60)%60);
            s=parseInt(lefttime%60);
    
            document.getElementById("LeftTime").innerHTML="还剩" + d+"天"+h+"小时"+m+"分"+s+"秒";
            if(lefttime<=0){
                    document.getElementById("LeftTime").innerHTML="团购已结束";
                    clearInterval(sh);
            }
    }
            FreshTime();
            var sh;
            sh=setInterval(FreshTime,1000);
    </script>
    </body>
    </html>

    通过这两个小demo 相信你已经全部知道了 Date对象了。


    系列文章导航:

    1、你不知道的JavaScript–Item1 严格模式

    2、你不知道的JavaScript–Item2 浮点数精度

    3、你不知道的JavaScript–Item3 隐式强制转换

    4、你不知道的JavaScript–Item4 基本类型和基本包装类型(引用类型)

    5、你不知道的JavaScript–Item5 全局变量

    6、你不知道的JavaScript–Item6 var预解析与函数声明提升(hoist )

    7、你不知道的JavaScript–Item7 函数和(命名)函数表达式

    8、你不知道的JavaScript–Item8 函数,方法,构造函数调用

    9、你不知道的JavaScript–Item9 call(),apply(),bind()与回调

    10、你不知道的JavaScript–Item10 闭包(closure)

    11、你不知道的JavaScript–Item11 arguments对象

    12、你不知道的JavaScript–Item12 undefined 与 null

    13、你不知道的JavaScript–Item13 理解 prototype, getPrototypeOf 和_ proto_

    14、你不知道的JavaScript–Item14 使用prototype的几点注意事项

    15、你不知道的JavaScript–Item15 prototype原型和原型链详解

    16、你不知道的JavaScript–Item16 for 循环和for…in 循环的那点事儿

    17、你不知道的JavaScript–Item17 循环与prototype最后的几点小tips

    18、你不知道的JavaScript–Item18 JScript的Bug与内存管理

    19、你不知道的JavaScript–Item19 执行上下文(execution context)

    20、你不知道的JavaScript–Item20 作用域与作用域链(scope chain)

    21、你不知道的JavaScript–Item21 漂移的this

    22、你不知道的JavaScript–Item22 Date对象全解析

    版权声明:本文为小平果原创文章,转载请注明:http://blog.csdn.net/i10630226

  • 相关阅读:
    C++虚函数表理解
    【转】c++虚函数实现原理
    【转】运输层TCP协议详细介绍
    【转】计算机中浮点数的表示
    ARP跨网段广播
    【转】arm和x86的区别
    面向对象六大原则
    安卓 热修复的原理
    Zygote和System进程的启动过程
    Android内存泄漏
  • 原文地址:https://www.cnblogs.com/dingxiaoyue/p/4948185.html
Copyright © 2020-2023  润新知