Hi I have the 3 javascript files.
In file1.js I have
jQuery.noConflict() jQuery(document).ready(function($) { // .... });
I get an error 'jQuery' was used before it was defined. and 'document' was used before it was defined.
How do I safely get rid of this warning.
If I do
var document = document || {};
then in my utility.js if it is used, it would be null in IE and ok in firefox.
What is the best solution to this?
The "'{a}' was used before it was defined" error (and the alternative "'{a}' is not defined" error) is thrown when JSLint, JSHint and ESLint encounter an identifier that has not been previously declared in a var statement or function declaration.
The first error pointed out by JSLint is that the "use strict" statement is missing. This error indicates that the function is not executed in strict mode. To correct this error, enable strict mode by adding the following string literal to the beginning of the function body.
From the documentation
JSLint also recognizes a /*global */ directive that can indicate to JSLint that variables used in this file were defined in other files. The comment can contain a comma separated list of names. Each name can optionally be followed by a colon and either true or false, true indicating that the variable may be assigned to by this file, and false indicating that assignment is not allowed (which is the default). The directive respects function scope.
Some globals can be predefined for you. Select the Assume a browser (browser) option to predefine the standard global properties that are supplied by web browsers, such as document and addEventListener.
Example:
/*jslint browser: true*/ /*global $, jQuery*/
As Quentin says, there's a /*global*/
directive.
Here is an example (put this at the top of the file):
/*global var1,var2,var3,var4,var5*/
Make sure the initial global statement is on the same line as /*
, or else it breaks.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With