Home >Web Front-end >JS Tutorial >Why is my jQuery code throwing an 'Uncaught ReferenceError: $ is not defined' error?
jQuery: The Elusive $ Variable
In the realm of web development, the jQuery library holds a prominent place. However, occasionally, developers encounter the perplexing error message "Uncaught ReferenceError: $ is not defined." To understand the cause of this error, let's delve into the inner workings of the jQuery library and the specific code snippet mentioned in the question.
The jQuery library, upon inclusion in a web page, defines the $ variable as a global object that simplifies the process of accessing and manipulating elements in the document object model (DOM). This global object, represented by the $ symbol, plays a crucial role in jQuery's operations.
In the provided code snippet, the error arises due to the improper sequencing of script references in the header section of the web page. The scripts for jQuery and its plugins should hold precedence. In the example, the sprinkle.js script, custom JavaScript for this project, is loaded before the jQuery library itself. This incorrect order prevents the jQuery library from initializing properly, resulting in the inability to access the $ variable and triggering the aforementioned error message.
To resolve this issue, the order of script references must be corrected. The jQuery library and its plugins should be referenced first, followed by any custom JavaScript. This ensures that the necessary objects are defined and available for use before the custom script attempts to utilize them.
Here's an adjusted version of the header code with the correct script loading sequence:
<script language="JavaScript" type="text/javascript" src="/js/jquery-1.2.6.min.js"></script> <script language="JavaScript" type="text/javascript" src="/js/jquery-ui-personalized-1.5.2.packed.js"></script> <script language="JavaScript" type="text/javascript" src="/js/sprinkle.js"></script>
With this modification, the jQuery library will be loaded first, followed by its plugin, and finally the sprinkle.js script. This proper sequencing allows the custom JavaScript to access the jQuery objects and resolves the error, resulting in properly functioning tab closing functionality on the web page.
The above is the detailed content of Why is my jQuery code throwing an 'Uncaught ReferenceError: $ is not defined' error?. For more information, please follow other related articles on the PHP Chinese website!