搜索
首页web前端js教程在 JavaScript 中获取日期之间的相对时间戳差异

在 JavaScript 中获取日期之间的相对时间戳差异

您是否在任何网站上看到过显示时间戳的通知?它显示诸如“12 分钟前”、“2 天前”、“10 小时前”等内容。它与两个日期或时间之间的时间戳差异有关。

此外,某些应用显示该设备的上次登录时间是 22 小时前。因此,获取两个日期之间的时间戳差异有很多用途。

在本教程中,我们将学习不同的方法来获取两个日期之间的相对时间戳差异。

使用带有日期的 getTime() 方法并创建自定义算法

在 JavaScript 中,我们可以使用 new Date() 构造函数创建日期对象。此外,我们可以将特定日期作为 Date() 构造函数的参数传递,以使用该日期值初始化日期对象。

getTime() 方法返回从 1970 年 1 月 1 日至今的总秒数。因此,我们可以找到两个日期的总毫秒数,然后减去它们以获得毫秒差。使用该毫秒,我们可以找到以秒、分钟、年等为单位的时间戳差异。

语法

用户可以按照下面的语法来获取两个日期之间的相对时间戳差异。

let second_diff = (current_date.getTime() - previous_date.getTime())/1000; 

在上面的语法中,current_date 和 pervious_date 是两个不同的日期。我们使用 getTime() 方法来获取两个日期之间的毫秒差。

注意- 通过将 second_diff 变量的值与毫秒进行比较,您可以获得相对时间戳差异。

步骤

用户可以按照以下步骤查找不同单位(例如天、月、年等)的两个日期之间的相对时间戳。

第 1 步 - 创建两个不同的日期。

步骤 2 - 使用 getTime() 方法获取两个日期的总毫秒数并获取它们之间的差值。另外,将毫秒差除以 1000 将其转换为秒,并将其存储在 secondary_diff 变量中。

步骤 3 - 现在,使用 if-else 条件语句来查找相对时间戳差异。

步骤 4 - 如果 second_diff 的 值小于 60,则差异以秒为单位。 Second_diff 的值在 60​​ 到 3600 之间,差异以小时为单位。用户还可以像这样计算日、月、年。

示例

在下面的示例中,我们使用 Date 构造函数创建了两个不同的日期对象,并使用上述步骤查找两个日期之间的相对时间戳。

在输出中,用户可以观察到以下代码代表月份的时间戳差异。

<html>
<body>
   <h3 id="Getting-the-relative-timestamp-difference-between-two-dates-using-the-i-custom-algorithm-i">Getting the relative timestamp difference between two dates using the <i> custom algorithm </i></h3>
   <p id="output"></p>
   <script>
      let output = document.getElementById("output");
      
      // creating the current date
      let current_date = new Date();
      
      // previous date
      let previous_date = new Date("jan 14, 2022 12:21:45");
      
      // finding the difference in total seconds between two dates
      let second_diff = (current_date.getTime() - previous_date.getTime()) / 1000;
      output.innerHTML += "The first date is " + current_date + "</br>";
      output.innerHTML += "The second date is " + previous_date + "</br>";
      
      // showing the relative timestamp.
      if (second_diff < 60) {
         output.innerHTML += "difference is of " + second_diff + " seconds.";
      } else if (second_diff < 3600) {
         output.innerHTML += "difference is of " + second_diff / 60 + " minutes.";
      } else if (second_diff < 86400) {
         output.innerHTML += "difference is of " + second_diff / 3600 + " hours.";
      } else if (second_diff < 2620800) {
         output.innerHTML += "difference is of " + second_diff / 86400 + " days.";
      } else if (second_diff < 31449600) {
         output.innerHTML += "difference is of " + second_diff / 2620800 + " months.";
      } else {
         output.innerHTML += "difference is of " + second_diff / 31449600 + " years.";
      }
   </script>
</body>
</html>

使用Intl的RelativeTimeFormat() API

Intl是指国际化API。它包含各种日期和时间格式化方法。我们可以使用 Intl 对象的 RelativeTimeFormat() 方法来获取两个日期之间的相对时间戳。

语法

用户可以按照以下语法使用RelativeTimeFormat() API 来获取两个日期之间的相对时间戳。

var relativeTimeStamp =
new Intl.RelativeTimeFormat("en", { numeric: "auto",});

// compare the value of RelativeTimeStamp with milliseconds of different time units

在上述语法中,RelativeTimeFormat() 方法返回时间戳差异。 time_Stamp_unit 是一个包含不同时间单位及其总毫秒数的对象。

步骤

第 1 步 - 创建一个单位对象,其中包含时间单位作为键,总毫秒数作为该时间单位的值。

步骤 2 - 获取两个日期之间的时间差(以毫秒为单位)。

第 3 步 - 现在使用 for-in 循环迭代 time_stamp_unit 对象并检查 second_diff 的值是否大于特定时间的总毫秒数;使用 RelativeTimeFormat() API 的 format 方法来格式化该特定单位的时间戳。

第 4 步 - 之后,中断 for 循环。

示例

在下面的示例中,我们使用 RelativeTimeFomrat() 方法来获取两个日期之间的相对时间戳差异,如上述语法和步骤中所述。

<html>
<body>
   <h3 id="Getting-the-relative-timestamp-difference-between-two-dates-using-the-i-RelativeTimeFormat-i-method">Getting the relative timestamp difference between two dates using the <i> RelativeTimeFormat() </i> method </h3>
   <p id="output"></p>
   <script>
      let output = document.getElementById("output");
      let current_date = new Date();
      let previous_date = new Date("jan 14, 2022 12:21:45");
      
      // finding the difference in total seconds between two dates 
      let second_diff = current_date.getTime() - previous_date.getTime();
      output.innerHTML += "The first date is " + current_date + "</br>";
      output.innerHTML += "The second date is " + previous_date + "</br>";
      var time_Stamp_unit = {
         year: 31536000000,
         month: 31536000000 / 12,
         day: 86400000,
         hour: 3600000,
         minute: 60000,
         second: 1000,
      };
      var relativeTimeStamp = new Intl.RelativeTimeFormat("en", {
         numeric: "auto",
      });
      
      // iterate through all time stamps
      for (var ele in time_Stamp_unit) {
         
         // if second_diff's value is greater than particular timesapm unit's total millisecond value, format accordingly
         if (Math.abs(second_diff) > time_Stamp_unit[ele] || ele == "second") {
            output.innerHTML += "The difference between two dates is " + relativeTimeStamp.format(
               Math.round(second_diff / time_Stamp_unit[ele]), ele
            );
            break;
         }
      }
   </script>
</body>
</html>

用户学会了使用 if-else 语句和 RelativeTimeFormat() API 的 format() 方法查找两个日期之间的相对时间戳。用户可以根据自己的需要使用这两种方法。

以上是在 JavaScript 中获取日期之间的相对时间戳差异的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:tutorialspoint。如有侵权,请联系admin@php.cn删除
JavaScript数据类型:浏览器和nodejs之间是否有区别?JavaScript数据类型:浏览器和nodejs之间是否有区别?May 14, 2025 am 12:15 AM

JavaScript核心数据类型在浏览器和Node.js中一致,但处理方式和额外类型有所不同。1)全局对象在浏览器中为window,在Node.js中为global。2)Node.js独有Buffer对象,用于处理二进制数据。3)性能和时间处理在两者间也有差异,需根据环境调整代码。

JavaScript评论:使用//和 / * * / * / * /JavaScript评论:使用//和 / * * / * / * /May 13, 2025 pm 03:49 PM

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python vs. JavaScript:开发人员的比较分析Python vs. JavaScript:开发人员的比较分析May 09, 2025 am 12:22 AM

Python和JavaScript的主要区别在于类型系统和应用场景。1.Python使用动态类型,适合科学计算和数据分析。2.JavaScript采用弱类型,广泛用于前端和全栈开发。两者在异步编程和性能优化上各有优势,选择时应根据项目需求决定。

Python vs. JavaScript:选择合适的工具Python vs. JavaScript:选择合适的工具May 08, 2025 am 12:10 AM

选择Python还是JavaScript取决于项目类型:1)数据科学和自动化任务选择Python;2)前端和全栈开发选择JavaScript。Python因其在数据处理和自动化方面的强大库而备受青睐,而JavaScript则因其在网页交互和全栈开发中的优势而不可或缺。

Python和JavaScript:了解每个的优势Python和JavaScript:了解每个的优势May 06, 2025 am 12:15 AM

Python和JavaScript各有优势,选择取决于项目需求和个人偏好。1.Python易学,语法简洁,适用于数据科学和后端开发,但执行速度较慢。2.JavaScript在前端开发中无处不在,异步编程能力强,Node.js使其适用于全栈开发,但语法可能复杂且易出错。

JavaScript的核心:它是在C还是C上构建的?JavaScript的核心:它是在C还是C上构建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; saninterpretedlanguagethatrunsonenginesoftenwritteninc.1)javascriptwasdesignedAsalightweight,解释edganguageforwebbrowsers.2)Enginesevolvedfromsimpleterterterpretpreterterterpretertestojitcompilerers,典型地提示。

JavaScript应用程序:从前端到后端JavaScript应用程序:从前端到后端May 04, 2025 am 12:12 AM

JavaScript可用于前端和后端开发。前端通过DOM操作增强用户体验,后端通过Node.js处理服务器任务。1.前端示例:改变网页文本内容。2.后端示例:创建Node.js服务器。

Python vs. JavaScript:您应该学到哪种语言?Python vs. JavaScript:您应该学到哪种语言?May 03, 2025 am 12:10 AM

选择Python还是JavaScript应基于职业发展、学习曲线和生态系统:1)职业发展:Python适合数据科学和后端开发,JavaScript适合前端和全栈开发。2)学习曲线:Python语法简洁,适合初学者;JavaScript语法灵活。3)生态系统:Python有丰富的科学计算库,JavaScript有强大的前端框架。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3 英文版

SublimeText3 英文版

推荐:为Win版本,支持代码提示!

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。