79

I am getting an error ReferenceError: performance is not defined when trying to use performance.now() to measure the execution time of a function call:

export async function find(someId: string, ctx: context.IContext) {

      try {
        var t0 = performance.now();

        var res = someModel.find(someId, ctx.cookies);

        var t1 = performance.now();
        console.log("Call to find took " + (t1 - t0) + " milliseconds.");

        return res;
      } catch (err) {
        console.error(err);
        throw err;
      }
    }

Any ideas how I can fix this?

8
  • 2
    where is performance defined? This is being done on client or server? Commented Sep 26, 2017 at 22:52
  • Are you using firefox-like browsers? Commented Sep 26, 2017 at 22:54
  • I am not defining it anywhere as I thought this is part of the standard library. Any help with how to do it? @Vatsal I am on Google Chrome. Commented Sep 26, 2017 at 22:55
  • Strange.. I just made a sample program. It works for me jsbin.com/vowinaloni/edit?js,console,output Commented Sep 26, 2017 at 22:59
  • look here: stackoverflow.com/questions/313893/… Commented Sep 26, 2017 at 23:02

5 Answers 5

147

I know this is tagged front-end but if anyone comes across this looking for a node.js solution (like me), you need to first require performance from the perf_hooks module (available in node 8.5+).

const {performance} = require('perf_hooks');
const t0 = performance.now();
...
Sign up to request clarification or add additional context in comments.

1 Comment

Thanks, it seems that performance is global in Node 16, but requires importing a module on older versions.
22

Since the 'perf_hook' module exports multiple constructs (objects, functions, constants, etc.), you will need to explicitly specify which construct you wish to use. In this case, you need the performance construct. The declaration can be done in two ways:

const performance = require('perf_hooks').performance;

or

const { performance } = require('perf_hooks'); //object destructuring

Comments

18

You will lose type information when using require, so the best way to import "performance" with TypeScript is using an import statement:

import {performance, PerformanceObserver} from 'perf_hooks';

const observer = new PerformanceObserver(items => items.getEntries().forEach((entry) => console.log(entry)));    
observer.observe({entryTypes: ['measure']});

performance.mark('start');
performance.mark('stop');
performance.measure('Measurement', 'start', 'stop');

Also make sure that you declared @types/node in your "dependencies" of "package.json".

Tested with TypeScript 4 & Node.js 14.

Comments

8

yes! like above answers you need to add this..

const {
      performance,
      PerformanceObserver
    } = require('perf_hooks');

but you can run performance.now() inside your browser console or in your browser -> source tab -> snippet without adding above code.

you can read this to get to know more about this..

https://nodejs.org/api/perf_hooks.html#perf_hooks_performance_now

Comments

3

For me it was on pristine next.js project, right after running installation wizard and adding apollo. Updating NODE to latest version solved the problem.

You can do with with nvm use 18 or by adding a .nvmrc file to the application.

2 Comments

As it’s currently written, your answer is unclear. Please edit to add additional details that will help others understand how this addresses the question asked. You can find more information on how to write good answers in the help center.
Why are people adding new answers about Node to a question tagged [frontend]?!?

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.