未捕获的引用错误使用外部脚本&jQuery移动

Uncaught ReferenceError using external script & jQuery Mobile

本文关键字:脚本 外部 jQuery 移动 引用 错误      更新时间:2023-09-26

我正在尝试创建一个web应用程序,但不能让我的javascript工作。

当加载一个新启动的浏览器页面时,我得到'未捕获的ReferenceError: getResult未定义'(位于js/ajax.js),但当我刷新页面时,一切都有效。我试图移动脚本加载发生的地方,但我不能让它工作。

我发现了一堆类似的问题,但他们似乎建议在里面加载脚本,而不是使用$(document).ready(),我已经这样做了。有人知道吗?

编辑:

我注意到这个错误只发生在从另一个jQuery移动页面。

index . html

<!DOCTYPE html>
<html>
<head>
    <title>sio.signalare.se</title>
    <meta content="width=device-width, user-scalable=no" name="viewport">
    <meta content="yes" name="apple-mobile-web-app-capable">
    <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.4.3/jquery.mobile-1.4.3.min.css" /> 
    <script src="js/ajax.js"></script>
    <script src="http://code.jquery.com/jquery-1.11.1.min.js"></script>
    <script src="http://code.jquery.com/mobile/1.4.3/jquery.mobile-1.4.3.min.js"></script>
    <style>
        .wrap {
            white-space: normal !important;
        }
    </style>
</head>
<body>
    <div data-role="page">
    <div data-role="header">
        <a class="ui-btn-left" data-direction="reverse" data-icon="back"
        data-iconpos="notext" href="../"></a>
        <h1>ATC-felkoder</h1>
    </div><!-- /header -->
    <div data-role="content">
        <ul data-inset="true" data-role="listview">
            <li>
                <h2 class="wrap">F1</h2>
                <p class="wrap"><strong id="F1-result"></strong></p>
                <select id="F1" onchange="getResult(this);">
                    <option value="" selected>Välj</option>
                    <option value="0">0</option>
                    <option value="1">1</option>
                    <option value="2">2</option>
                    <option value="3">3</option>
                    <option value="4">4</option>
                    <option value="5">5</option>
                    <option value="6">6</option>
                    <option value="7">7</option>
                    <option value="8">8</option>
                    <option value="9">9</option>
                    <option value="A">A</option>
                    <option value="C">C</option>
                    <option value="E">E</option>
                    <option value="F">F</option>
                    <option value="H">H</option>
                    <option value="L">L</option>
                    <option value="P">P</option>
                    <option value="U">U</option>
                </select>
            </li>
        </ul>
        <h6>Version 2.0</h6>
    </div><!-- /content -->
</div><!-- /page -->
</body>
</html>
js/ajax.js

function getResult(e) {
    if (e.value) {
        var ajax_load = "<img src='img/loader.gif' alt='loading...' />";
        var loadUrl = "data/result.php?args=" + e.id + "|" + e.value;
        $("#" + e.id + "-result").load(loadUrl);
    } else {
        $("#" + e.id + "-result").empty();
    }        
}

;使用jQuery Mobile时,TLDR: <head>在内部页面上被忽略。

使用jQuery移动与外部样式和脚本,你将不得不加载相同的脚本和样式的每一个页面,根据文档