Disallow new require (no-new-require)
The require
function is used to include modules that exist in separate files, such as:
var appHeader = require('app-header');
Some modules return a constructor which can potentially lead to code such as:
var appHeader = new require('app-header');
Unfortunately, this introduces a high potential for confusion since the code author likely meant to write:
var appHeader = new (require('app-header'));
For this reason, it is usually best to disallow this particular expression.
Rule Details
This rule aims to eliminate use of the new require
expression.
Examples of incorrect code for this rule:
/*eslint no-new-require: "error"*/
var appHeader = new require('app-header');
Examples of correct code for this rule:
/*eslint no-new-require: "error"*/
var AppHeader = require('app-header');
var appHeader = new AppHeader();
When Not To Use It
If you are using a custom implementation of require
and your code will never be used in projects where a standard require
(CommonJS, Node.js, AMD) is expected, you can safely turn this rule off.
Version
This rule was introduced in ESLint 0.6.0.