未捕获的 ReferenceError:$ 未在 jQuery 中定义错误

IT技术 javascript jquery html file-io
2021-02-19 20:41:54

我有这段代码jQuery:(文件名是 javascript.js ...我之前使用过 JavaScript ...)

$(document).ready(function() {
 $("#readFile").click(function() {
    $.get('test.txt', function(data) {
      $("#bottom_pane_options").html(data); // #bottom_pane_options is the div I want the data to go
    }, 'text');
 });
});

...这在 HTML 中:

<!DOCTYPE html>
<html>
<head>
    <title>Culminating</title>
    <link href="style.css" rel="stylesheet" type="text/css">

    <script type="text/javascript" src="./javascript.js"></script>
    <script
        src="http://maps.googleapis.com/maps/api/js?key=AIzaSyCJnj2nWoM86eU8Bq2G4lSNz3udIkZT4YY&sensor=false">
    </script>

    <script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script>


    <script>
        function initialize()
        {
        var mapProp = {
          center:new google.maps.LatLng(50.569283,-84.378433),
          zoom:5,
          mapTypeId:google.maps.MapTypeId.TERRAIN
          };
        var map=new google.maps.Map(document.getElementById("googleMap"),mapProp);
        }

        google.maps.event.addDomListener(window, 'load', initialize);
    </script>
</head>

<body>
    <div class="content">
        <div id="googleMap"></div>
        <div id="right_pane_results">hi</div>
        <div id="bottom_pane_options">
            <button id="readFile">Read File</button>
        </div>
    </div>
</body>

当我检查控制台时,我得到了第一行未定义Uncaught ReferenceError说法$我假设它指的是第一行的第一个字符。我从一个网站上得到了这个代码,我是新手,jQuery所以我不确定这里出了什么问题。

有什么建议?

4个回答

更改包含脚本的顺序(首先使用 jQuery):

<script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script>
<script type="text/javascript" src="./javascript.js"></script>
<script
    src="http://maps.googleapis.com/maps/api/js?key=YOUR_APIKEY&sensor=false">
</script>
谢谢。你的回答解决了这个问题。但是现在我收到一个错误,说我缺少Access-Control-Allow-Origin标题。我知道我需要添加,Allow-Control-Access-Origin: *但我不知道把它放在哪里
2021-04-18 20:41:54

首先包含 jQuery 文件:

 <script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script>
 <script type="text/javascript" src="./javascript.js"></script>
    <script
        src="http://maps.googleapis.com/maps/api/js?key=AIzaSyCJnj2nWoM86eU8Bq2G4lSNz3udIkZT4YY&sensor=false">
    </script>

脚本按照您在 HTML 中定义的顺序加载。

因此,如果您第一次加载:

<script type="text/javascript" src="./javascript.js"></script>

无需先加载 jQuery,然后$ is not defined.

您需要先加载 jQuery 才能使用它。

出于性能原因,我还建议将您的脚本放在 HTML 的底部。

...按顺序加载和解释。OP 的假设似乎是它们仅在所有加载后才被解释。
2021-05-01 20:41:54

MVC 5 stock install 将javascript 引用放在_Layout.cshtml 文件中,该文件在所有页面中共享。因此,javascript 文件位于我所有 $ 所在的主要内容和 document.ready 函数之下。

_Layout.cshtml 的底部部分:

    <div class="container body-content">
        @RenderBody()
        <hr />
        <footer>
            <p>&copy; @DateTime.Now.Year - My ASP.NET Application</p>
        </footer>
    </div>

    @Scripts.Render("~/bundles/jquery")
    @Scripts.Render("~/bundles/bootstrap")
    @RenderSection("scripts", required: false)

</body>
</html>

我将它们移到 @RenderBody() 上方,一切都很好。

    @Scripts.Render("~/bundles/jquery")
    @Scripts.Render("~/bundles/bootstrap")
    @RenderSection("scripts", required: false)

    <div class="container body-content">
        @RenderBody()
        <hr />
        <footer>
            <p>&copy; @DateTime.Now.Year - My ASP.NET Application</p>
        </footer>
    </div>

</body>
</html>