Files
30-seconds-of-code/snippets/isBrowser.md
Isabelle Viktoria Maciohsek 8bf67754ce Make expertise a field
2022-03-01 20:21:45 +02:00

889 B

title, tags, expertise, firstSeen, lastUpdated
title tags expertise firstSeen lastUpdated
Environment is browser browser,node intermediate 2018-03-19T04:50:55+02:00 2020-10-20T23:02:01+03:00

Determines if the current runtime environment is a browser so that front-end modules can run on the server (Node) without throwing errors.

  • Use Array.prototype.includes() on the typeof values of both Window and Document (globals usually only available in a browser environment unless they were explicitly defined), which will return true if one of them is undefined.
  • typeof allows globals to be checked for existence without throwing a ReferenceError.
  • If both of them are not undefined, then the current environment is assumed to be a browser.
const isBrowser = () => ![typeof window, typeof document].includes('undefined');
isBrowser(); // true (browser)
isBrowser(); // false (Node)