JavaScript中常见的获取当前日期方法

 更新时间:2024年06月20日 15:34:15   作者:阿里嘎多学长  
在我们开发的许多应用程序都会用到某种日期功能,无论是内容的创建日期还是活动的时间戳等等,这篇文章主要给大家介绍了关于JavaScript中常见的获取当前日期方法,需要的朋友可以参考下

在 JavaScript 中,获取当前日期可以使用 Date 对象。以下是几种常见的获取当前日期的方法:

获取当前日期的完整对象:

var currentDate = new Date();

获取当前日期的年、月、日等单独部分:

var year = currentDate.getFullYear(); // 获取完整的年份
var month = currentDate.getMonth() + 1; // 获取月份,注意 JavaScript 中月份是从 0 开始计数的
var day = currentDate.getDate(); // 获取日期

获取当前日期的字符串表示:

var dateString = currentDate.toString(); // 获取日期的字符串表示,格式为 "Wed Apr 26 2024 00:00:00 GMT+0800 (中国标准时间)"

格式化日期字符串:

如果你需要特定的日期格式,可以使用 Date 对象的 toLocaleString()toDateString() 或 toISOString() 方法,或者自己构建格式化函数。

使用 toLocaleDateString() 来获取本地日期格式的字符串:

var localDateString = currentDate.toLocaleDateString();

使用 toISOString() 来获取 ISO 格式的日期字符串:

var isoString = currentDate.toISOString();

自定义日期格式:

如果你需要自定义日期格式,可以使用 Date 对象的 get 方法结合模板字符串或 padStart 方法来格式化日期。

例如,自定义格式 “YYYY-MM-DD”:

function formatLocalDate(date) {
  return (
    date.getFullYear() + '-' +
    (date.getMonth() + 1).toString().padStart(2, '0') + '-' +
    date.getDate().toString().padStart(2, '0')
  );
}
var formattedDate = formatLocalDate(currentDate);

以上是一些基本的获取和处理当前日期的方法。你可以根据需要选择使用。

补充知识:更多操作方法

//---------------------------------------------------      
// 判断闰年      
//---------------------------------------------------      
Date.prototype.isLeapYear = function()       
{       
    return (0==this.getYear()%4&&((this.getYear()%100!=0)||(this.getYear()%400==0)));       
}       
      
//---------------------------------------------------      
// 日期格式化      
// 格式 YYYY/yyyy/YY/yy 表示年份      
// MM/M 月份      
// W/w 星期      
// dd/DD/d/D 日期      
// hh/HH/h/H 时间      
// mm/m 分钟      
// ss/SS/s/S 秒      
//---------------------------------------------------      
Date.prototype.Format = function(formatStr)       
{       
    var str = formatStr;       
    var Week = ['日','一','二','三','四','五','六'];      
      
    str=str.replace(/yyyy|YYYY/,this.getFullYear());       
    str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear() % 100).toString():'0' + (this.getYear() % 100));       
      
    str=str.replace(/MM/,this.getMonth()>9?this.getMonth().toString():'0' + this.getMonth());       
    str=str.replace(/M/g,this.getMonth());       
      
    str=str.replace(/w|W/g,Week[this.getDay()]);       
      
    str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0' + this.getDate());       
    str=str.replace(/d|D/g,this.getDate());       
      
    str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0' + this.getHours());       
    str=str.replace(/h|H/g,this.getHours());       
    str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0' + this.getMinutes());       
    str=str.replace(/m/g,this.getMinutes());       
      
    str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0' + this.getSeconds());       
    str=str.replace(/s|S/g,this.getSeconds());       
      
    return str;       
}       
      
//+---------------------------------------------------      
//| 求两个时间的天数差 日期格式为 YYYY-MM-dd       
//+---------------------------------------------------      
function daysBetween(DateOne,DateTwo)      
{       
    var OneMonth = DateOne.substring(5,DateOne.lastIndexOf ('-'));      
    var OneDay = DateOne.substring(DateOne.length,DateOne.lastIndexOf ('-')+1);      
    var OneYear = DateOne.substring(0,DateOne.indexOf ('-'));      
      
    var TwoMonth = DateTwo.substring(5,DateTwo.lastIndexOf ('-'));      
    var TwoDay = DateTwo.substring(DateTwo.length,DateTwo.lastIndexOf ('-')+1);      
    var TwoYear = DateTwo.substring(0,DateTwo.indexOf ('-'));      
      
    var cha=((Date.parse(OneMonth+'/'+OneDay+'/'+OneYear)- Date.parse(TwoMonth+'/'+TwoDay+'/'+TwoYear))/86400000);       
    return Math.abs(cha);      
}      
      
      
//+---------------------------------------------------      
//| 日期计算      
//+---------------------------------------------------      
Date.prototype.DateAdd = function(strInterval, Number) {       
    var dtTmp = this;      
    switch (strInterval) {       
        case 's' :return new Date(Date.parse(dtTmp) + (1000 * Number));      
        case 'n' :return new Date(Date.parse(dtTmp) + (60000 * Number));      
        case 'h' :return new Date(Date.parse(dtTmp) + (3600000 * Number));      
        case 'd' :return new Date(Date.parse(dtTmp) + (86400000 * Number));      
        case 'w' :return new Date(Date.parse(dtTmp) + ((86400000 * 7) * Number));      
        case 'q' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());      
        case 'm' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());      
        case 'y' :return new Date((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds());      
    }      
}      
      
//+---------------------------------------------------      
//| 比较日期差 dtEnd 格式为日期型或者 有效日期格式字符串      
//+---------------------------------------------------      
Date.prototype.DateDiff = function(strInterval, dtEnd) {       
    var dtStart = this;      
    if (typeof dtEnd == 'string' )//如果是字符串转换为日期型      
    {       
        dtEnd = StringToDate(dtEnd);      
    }      
    switch (strInterval) {       
        case 's' :return parseInt((dtEnd - dtStart) / 1000);      
        case 'n' :return parseInt((dtEnd - dtStart) / 60000);      
        case 'h' :return parseInt((dtEnd - dtStart) / 3600000);      
        case 'd' :return parseInt((dtEnd - dtStart) / 86400000);      
        case 'w' :return parseInt((dtEnd - dtStart) / (86400000 * 7));      
        case 'm' :return (dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) - (dtStart.getMonth()+1);      
        case 'y' :return dtEnd.getFullYear() - dtStart.getFullYear();      
    }      
}      
      
//+---------------------------------------------------      
//| 日期输出字符串,重载了系统的toString方法      
//+---------------------------------------------------      
Date.prototype.toString = function(showWeek)      
{       
    var myDate= this;      
    var str = myDate.toLocaleDateString();      
    if (showWeek)      
    {       
        var Week = ['日','一','二','三','四','五','六'];      
        str += ' 星期' + Week[myDate.getDay()];      
    }      
    return str;      
}      
      
//+---------------------------------------------------      
//| 日期合法性验证      
//| 格式为:YYYY-MM-DD或YYYY/MM/DD      
//+---------------------------------------------------      
function IsValidDate(DateStr)       
{       
    var sDate=DateStr.replace(/(^\s+|\s+$)/g,''); //去两边空格;       
    if(sDate=='') return true;       
    //如果格式满足YYYY-(/)MM-(/)DD或YYYY-(/)M-(/)DD或YYYY-(/)M-(/)D或YYYY-(/)MM-(/)D就替换为''       
    //数据库中,合法日期可以是:YYYY-MM/DD(2003-3/21),数据库会自动转换为YYYY-MM-DD格式       
    var s = sDate.replace(/[\d]{ 4,4 }[\-/]{ 1 }[\d]{ 1,2 }[\-/]{ 1 }[\d]{ 1,2 }/g,'');       
    if (s=='') //说明格式满足YYYY-MM-DD或YYYY-M-DD或YYYY-M-D或YYYY-MM-D       
    {       
        var t=new Date(sDate.replace(/\-/g,'/'));       
        var ar = sDate.split(/[-/:]/);       
        if(ar[0] != t.getYear() || ar[1] != t.getMonth()+1 || ar[2] != t.getDate())       
        {       
            //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');       
            return false;       
        }       
    }       
    else       
    {       
        //alert('错误的日期格式!格式为:YYYY-MM-DD或YYYY/MM/DD。注意闰年。');       
        return false;       
    }       
    return true;       
}       
      
//+---------------------------------------------------      
//| 日期时间检查      
//| 格式为:YYYY-MM-DD HH:MM:SS      
//+---------------------------------------------------      
function CheckDateTime(str)      
{       
    var reg = /^(\d+)-(\d{ 1,2 })-(\d{ 1,2 }) (\d{ 1,2 }):(\d{ 1,2 }):(\d{ 1,2 })$/;       
    var r = str.match(reg);       
    if(r==null)return false;       
    r[2]=r[2]-1;       
    var d= new Date(r[1],r[2],r[3],r[4],r[5],r[6]);       
    if(d.getFullYear()!=r[1])return false;       
    if(d.getMonth()!=r[2])return false;       
    if(d.getDate()!=r[3])return false;       
    if(d.getHours()!=r[4])return false;       
    if(d.getMinutes()!=r[5])return false;       
    if(d.getSeconds()!=r[6])return false;       
    return true;       
}       
      
//+---------------------------------------------------      
//| 把日期分割成数组      
//+---------------------------------------------------      
Date.prototype.toArray = function()      
{       
    var myDate = this;      
    var myArray = Array();      
    myArray[0] = myDate.getFullYear();      
    myArray[1] = myDate.getMonth();      
    myArray[2] = myDate.getDate();      
    myArray[3] = myDate.getHours();      
    myArray[4] = myDate.getMinutes();      
    myArray[5] = myDate.getSeconds();      
    return myArray;      
}      
      
//+---------------------------------------------------      
//| 取得日期数据信息      
//| 参数 interval 表示数据类型      
//| y 年 m月 d日 w星期 ww周 h时 n分 s秒      
//+---------------------------------------------------      
Date.prototype.DatePart = function(interval)      
{       
    var myDate = this;      
    var partStr='';      
    var Week = ['日','一','二','三','四','五','六'];      
    switch (interval)      
    {       
        case 'y' :partStr = myDate.getFullYear();break;      
        case 'm' :partStr = myDate.getMonth()+1;break;      
        case 'd' :partStr = myDate.getDate();break;      
        case 'w' :partStr = Week[myDate.getDay()];break;      
        case 'ww' :partStr = myDate.WeekNumOfYear();break;      
        case 'h' :partStr = myDate.getHours();break;      
        case 'n' :partStr = myDate.getMinutes();break;      
        case 's' :partStr = myDate.getSeconds();break;      
    }      
    return partStr;      
}      
      
//+---------------------------------------------------      
//| 取得当前日期所在月的最大天数      
//+---------------------------------------------------      
Date.prototype.MaxDayOfDate = function()      
{       
    var myDate = this;      
    var ary = myDate.toArray();      
    var date1 = (new Date(ary[0],ary[1]+1,1));      
    var date2 = date1.dateAdd(1,'m',1);      
    var result = dateDiff(date1.Format('yyyy-MM-dd'),date2.Format('yyyy-MM-dd'));      
    return result;      
}      
      
//+---------------------------------------------------      
//| 取得当前日期所在周是一年中的第几周      
//+---------------------------------------------------      
Date.prototype.WeekNumOfYear = function()      
{       
    var myDate = this;      
    var ary = myDate.toArray();      
    var year = ary[0];      
    var month = ary[1]+1;      
    var day = ary[2];      
    document.write('< script language=VBScript\> \n');      
    document.write('myDate = DateValue(''+month+'-'+day+'-'+year+'') \n');      
    document.write('result = DatePart('ww', myDate) \n');      
    document.write(' \n');      
    return result;      
}      
      
//+---------------------------------------------------      
//| 字符串转成日期类型       
//| 格式 MM/dd/YYYY MM-dd-YYYY YYYY/MM/dd YYYY-MM-dd      
//+---------------------------------------------------      
function StringToDate(DateStr)      
{       
      
    var converted = Date.parse(DateStr);      
    var myDate = new Date(converted);      
    if (isNaN(myDate))      
    {       
        //var delimCahar = DateStr.indexOf('/')!=-1?'/':'-';      
        var arys= DateStr.split('-');      
        myDate = new Date(arys[0],--arys[1],arys[2]);      
    }      
    return myDate;      
}   

总结

到此这篇关于JavaScript中常见的获取当前日期方法的文章就介绍到这了,更多相关js获取当前日期内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Javascript前端事件循环机制详细讲解

    Javascript前端事件循环机制详细讲解

    单线程的同步等待极大影响效率,任务不得不一个一个等待执行,对于网页应用是无法接受的。所以Javascript使用事件循环机制来解决异步任务的问题。本文就来讲讲Javascript的事件循环机制,希望对你有所帮助
    2022-12-12
  • JavaScript四种调用模式和this示例介绍

    JavaScript四种调用模式和this示例介绍

    JavaScript调用时除了声明时定义的形参外,每个函数接受两个附加参数:this 和arguments,下面为大家介绍下JavaScript四种调用模式和this
    2014-01-01
  • 如何实现textarea里的不同文本显示不同颜色

    如何实现textarea里的不同文本显示不同颜色

    如何实现textarea里的不同文本显示不同颜色呢?控制textarea的style设置Textarea以及把文本放到标记里都不会起作用,下面有个不错的解决方法,感兴趣的朋友可以了解下
    2014-01-01
  • javascript实现类似java中getClass()得到对象类名的方法

    javascript实现类似java中getClass()得到对象类名的方法

    这篇文章主要介绍了javascript实现类似java中getClass()得到对象类名的方法,实例分析了javascript实现java中getClass方法的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • JS实现拖动模糊框特效

    JS实现拖动模糊框特效

    这篇文章主要为大家详细介绍了JS实现拖动模糊框特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • IE图片缓存document.execCommand("BackgroundImageCache",false,true)

    IE图片缓存document.execCommand("BackgroundImageCache",

    IE6下设置背景图片是不会被真正cache住的,就算服务器做了cache,如果想cache住只能
    2011-03-03
  • JavaScript解构赋值的实用技巧指南

    JavaScript解构赋值的实用技巧指南

    JavaScript解构赋值为我们提供了很多方便,但是用法比较多,本文就来梳理一下,下面这篇文章主要给大家介绍了关于JavaScript解构赋值的实用技巧指南,需要的朋友可以参考下
    2022-01-01
  • JavaScript实现QQ聊天消息展示和评论提交功能

    JavaScript实现QQ聊天消息展示和评论提交功能

    这篇文章主要为大家详细介绍了JavaScript实现QQ聊天消息展示和评论提交功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • 微信小程序使用uni-app实现首页搜索框导航栏功能详解

    微信小程序使用uni-app实现首页搜索框导航栏功能详解

    这篇文章主要介绍了微信小程序使用uni-app实现首页搜索框导航栏功能,uni-app 是一个使用 Vue.js (opens new window)开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、Web(响应式)、以及各种小程序
    2022-10-10
  • 基于js 各种排序方法和sort方法的区别(详解)

    基于js 各种排序方法和sort方法的区别(详解)

    下面小编就为大家分享一篇基于js 各种排序方法和sort方法的区别(详解),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01

最新评论