performance.now() vs Date.now()

performance.now()Date.now() 是 JavaScript 中用于获取当前时间的两种不同的方法,但它们有几个关键区别:

  1. 精度和分辨率:

    • performance.now() 提供的时间戳具有高精度,通常可以精确到微秒(千分之一毫秒),并且是自页面加载(或工作线程启动)以来经过的时间。
    • Date.now() 提供的时间戳精度较低,通常精确到毫秒,表示自 Unix 纪元(1970年1月1日 UTC)以来经过的时间。
  2. 用途:

    • performance.now() 主要用于性能测量和基准测试,因为它可以提供更高精度的时间测量,且不受系统时间的调整(如更改系统时间或同步时间)的影响。
    • Date.now() 通常用于获取当前日期和时间,可以用于创建日期对象或进行日期时间计算。
  3. 相对于系统时钟:

    • performance.now() 是单调的,也就是说,它的值只会增加,不会因系统时间更改而受到影响。
    • Date.now() 可以受到系统时间调整的影响,如果系统时间被修改,返回的值可能会向前或向后跳跃。
  4. 兼容性:

    • performance.now() 是 HTML5 Performance API 的一部分,它在现代浏览器中得到广泛支持,但在老旧浏览器中可能不可用。
    • Date.now() 具有更广泛的兼容性,几乎在所有 JavaScript 环境中都可用。

示例:

js 复制代码
// 使用 performance.now()
var start = performance.now();
// 执行一些操作...
var end = performance.now();
console.log(`操作耗时:${end - start} 毫秒`);

// 使用 Date.now()
var start = Date.now();
// 执行一些操作...
var end = Date.now();
console.log(`操作耗时:${end - start} 毫秒`);

总结来说,如果你需要进行精确的时间测量,尤其是性能分析,应该使用 performance.now()。如果你只需要获取当前时间或进行普通的时间日期操作,可以使用 Date.now()

相关推荐
敲敲了个代码7 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
dly_blog8 小时前
Vue 响应式陷阱与解决方案(第19节)
前端·javascript·vue.js
消失的旧时光-19439 小时前
401 自动刷新 Token 的完整架构设计(Dio 实战版)
开发语言·前端·javascript
console.log('npc')9 小时前
Table,vue3在父组件调用子组件columns列的方法展示弹窗文件预览效果
前端·javascript·vue.js
用户47949283569159 小时前
React Hooks 的“天条”:为啥绝对不能写在 if 语句里?
前端·react.js
我命由我123459 小时前
SVG - SVG 引入(SVG 概述、SVG 基本使用、SVG 使用 CSS、SVG 使用 JavaScript、SVG 实例实操)
开发语言·前端·javascript·css·学习·ecmascript·学习方法
用户479492835691510 小时前
给客户做私有化部署,我是如何优雅搞定 NPM 依赖管理的?
前端·后端·程序员
C_心欲无痕10 小时前
vue3 - markRaw标记为非响应式对象
前端·javascript·vue.js
qingyun98910 小时前
深度优先遍历:JavaScript递归查找树形数据结构中的节点标签
前端·javascript·数据结构
胡楚昊10 小时前
NSSCTF动调题包通关
开发语言·javascript·算法