前端:如何在 JavaScript 中获取当前日期

简介:   在我们开发的许多应用程序都会用到某种日期功能,无论是内容的创建日期还是活动的时间戳等等。  处理日期和时间戳格式可能会很麻烦。在本文中,我们将一起学习如何在 JavaScript 中以各种格式获取当前日期。  JavaScript具有一个内置 Date 对象,该对象存储日期和时间并提供相应的处理日期和时间的方法。  要创建 Date 对象的新实例,请使用 new 关键字:

  在我们开发的许多应用程序都会用到某种日期功能,无论是内容的创建日期还是活动的时间戳等等。

  处理日期和时间戳格式可能会很麻烦。在本文中,我们将一起学习如何在 JavaScript 中以各种格式获取当前日期。

  JavaScript具有一个内置 Date 对象,该对象存储日期和时间并提供相应的处理日期和时间的方法。

  要创建 Date 对象的新实例,请使用 new 关键字:

  const date=new Date();

  该 Date 对象包含一个 Number,表示从新纪元(即1970年1月1日)起经过的毫秒数。

  您可以将日期字符串传递给 Date 构造函数以创建指定日期的对象:

  const date=new Date('Jul 12 2011');

  要获取当前年份,可以使用Date对象的 getFullYear() 实例方法 。getFullYear() 方法返回日期对应的年份:

  const currentYear=date.getFullYear();console.log(currentYear); //2020

  同样,有一些方法可以获取当月的当前日期和当前的月份:

  const today=date.getDate();const currentMonth=date.getMonth() + 1;

  getDate() 方法返回当月的当前日期(1-31)。

  getMonth() 方法返回指定日期的月份。需要注意的一点是, getMonth()方法返回的是索引值(0-11),其中0表示一月,11表示十二月。因此,加1可以使月份的值标准化。

  now()是 Date 对象的静态方法。它返回以毫秒为单位的值,该值表示自纪元以来经过的时间。您可以将now()方法返回的毫秒数传递给Date 构造函数以实例化新的 Date 对象:

  const timeElapsed=Date.now();const today=new Date(timeElapsed);

  我们可以使用Date对象的方法将二手设备网日期格式化为多种格式(GMT,ISO等)。

  toDateString()方法以人类可读的格式返回日期:

  today.toDateString(); // "Sun Jun 14 2020"

  toISOString()方法返回遵循ISO 8601扩展格式的日期:

  today.toISOString(); // "2020-06-13T18:30:00.000Z"

  toUTCString()方法以UTC时区格式返回日期:

  today.toUTCString(); // "Sat, 13 Jun 2020 18:30:00 GMT"

  toLocaleDateString()方法以对地区敏感的格式返回日期:

  today.toLocaleDateString(); // "6/14/2020"

  我们可以在MDN文档中找到Date有关方法的完整参考。

  除了上一节中提到的格式外,我们开发应用程序可能具有不同的数据格式。它可以是yy年mm月dd日或yyyy-dd-mm格式,或者类似的东西。

  为了解决这个问题,最好创建一个可重用的日期格式化函数,以便可以在多个项目中使用它。

  因此,在本节中,我们会创建一个函数,该函数将接收时间格式作为参数,返回对应格式的日期:

  const today=new Date();function formatDate(date, format) { //}formatDate(today, 'mm/dd/yy');

  我们需要给函数传递格式字符串,字符串中的月份,日期和年份分别用“ mm”,“ dd”,“ yy”来代替。

  有了这个格式字符串,我们就可以使用replace()来替换字符串中对应的部分,如下所示:

  format.replace('mm', date.getMonth() + 1);

  但这样会形成链式调用,而且会影响我们函数的灵活度:

  format.replace('mm', date.getMonth() + 1) .replace('yy', date.getFullYear()) .replace('dd', date.getDate());

  所以我们可以使用正则表达式代替方法来replace()。

  首先创建一个对象,该对象将代表子字符串的键值对及其各自的值:

  const formatMap = { mm: date.getMonth() + 1, dd: date.getDate(), yy: date.getFullYear().toString().slice(-2), yyyy: date.getFullYear()};

  接下来,使用正则表达式匹配并替换字符串:

  formattedDate=format.replace(/mm|dd|yy|yyy/gi, matched=> map[matched]);

  完整的功能如下所示:

  function formatDate(date, format) { const map={ mm: date.getMonth() + 1, dd: date.getDate(), yy: date.getFullYear().toString().slice(-2), yyyy: date.getFullYear() } return format.replace(/mm|dd|yy|yyy/gi, matched=> map[matched])}

  希望通过这篇文章,能让你对JavaScript 中的Date对象有更好的了解。

  其实你还可以使用其他第三方库(例如datesj和moment)来处理日期。

目录
相关文章
|
JavaScript 定位技术
vue中滚轮缩放事件
vue中滚轮缩放事件
189 0
|
4月前
|
机器学习/深度学习 存储 算法
如何判断两张图片的相似度?原来图片对比也可以如此简单!
本文介绍了图片对比技术在多个场景中的应用,如图片去重、内容审核、版权维权及相似图片搜索,并详细解析了两种主流的图片对比方法。第一种是**MD5指纹对比**,适合精确匹配完全相同的图片,具有速度快、简单易用的特点,但对稍作修改的图片无能为力。第二种是**图像哈希对比**,包括平均哈希、感知哈希等算法,能够判断图片的相似程度,适用于处理缩放、旋转或亮度调整后的图片,但在语义相似性上仍有局限。最后提到,随着机器学习和深度神经网络的发展,图片相似度判断技术将有更多可能性,值得进一步探索。
1499 6
如何判断两张图片的相似度?原来图片对比也可以如此简单!
|
算法 索引 智能硬件
智能家居系统
【9月更文挑战第05天】
187 6
|
12月前
|
存储 缓存 监控
|
8月前
|
机器学习/深度学习 人工智能 自然语言处理
《深度揭秘:DeepSeek如何解锁自然语言处理密码》
DeepSeek是基于Transformer架构的自然语言处理(NLP)佼佼者,通过自注意力机制高效捕捉长距离依赖关系,优化语义理解和生成。预训练阶段,DeepSeek利用海量文本数据学习语法、语义等知识,确保多义词的准确理解与翻译。监督微调和强化学习从人类反馈进一步提升模型性能,使其在智能客服、写作辅助、信息检索等领域广泛应用,为AI语言应用开辟新道路。
257 2
|
11月前
|
算法 调度 UED
深入浅出操作系统调度策略
【10月更文挑战第33天】在数字时代的心脏,操作系统扮演着至关重要的角色。本文将探讨操作系统的核心功能之一——进程调度策略的设计与影响。我们将从理论到实践,通过浅显易懂的语言和具体代码示例,揭示如何通过不同的调度算法来优化系统性能和用户体验。无论你是技术新手还是资深开发者,这篇文章都将为你提供新的视角和深入的理解。
|
消息中间件 小程序 Java
【规范】看看人家Git提交描述,那叫一个规矩
本文通过IDEA中的Git描述规范插件【git commit message helper】,介绍了Git提交描述的规范流程,强调了团队开发中统一标准的重要性,并通过实例展示了规范的提交记录如何提高代码管理和维护效率。最后,文章提供了几个实用的Git提交描述案例,帮助读者更好地理解和应用这些规范。
3065 0
【规范】看看人家Git提交描述,那叫一个规矩
|
Java 对象存储
【工具类】使用阿里oss实现图片、视频、文档上传
【工具类】使用阿里oss实现图片、视频、文档上传
977 0
|
Kubernetes Go API
|
机器学习/深度学习 人工智能 算法
【机器学习】平均绝对误差 (MAE) 与均方误差 (MSE) 有什么区别?
【5月更文挑战第17天】【机器学习】平均绝对误差 (MAE) 与均方误差 (MSE) 有什么区别?