1 # disallow `with` statements (no-with)
3 The `with` statement is potentially problematic because it adds members of an object to the current scope, making it impossible to tell what a variable inside the block actually refers to.
7 This rule disallows `with` statements.
9 If ESLint parses code in strict mode, the parser (instead of this rule) reports the error.
11 Examples of **incorrect** code for this rule:
14 /*eslint no-with: "error"*/
17 r = Math.sqrt(x * x + y * y); // is r a member of point?
21 Examples of **correct** code for this rule:
24 /*eslint no-with: "error"*/
27 const r = ({x, y}) => Math.sqrt(x * x + y * y);
32 If you intentionally use `with` statements then you can disable this rule.
36 * [with Statement Considered Harmful](https://yuiblog.com/blog/2006/04/11/with-statement-considered-harmful/)