product/node_modules/detect-node
Ruikang Zhang e96405c650 Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
..
LICENSE Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
Readme.md Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
browser.js Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
index.esm.js Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
index.js Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
package.json Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00

Readme.md

Install

npm install --save detect-node

Usage:

var isNode = require('detect-node');

if (isNode) {
  console.log("Running under Node.JS");
} else {
  alert("Hello from browser (or whatever not-a-node env)");
}

The check is performed as:

module.exports = false;

// Only Node.JS has a process variable that is of [[Class]] process
try {
 module.exports = Object.prototype.toString.call(global.process) === '[object process]' 
} catch(e) {}

Thanks to Ingvar Stepanyan for the initial idea. This check is both the most reliable I could find and it does not use process env directly, which would cause browserify to include it into the build.