gpt4 book ai didi

使用 <script> 标记从外部 JS 文件引用的 JavaScript 函数报告为 "not defined"

转载 作者:行者123 更新时间:2023-11-27 23:36:57 26 4
gpt4 key购买 nike

编辑:请参阅下面我的答案,因为它现在有效:)

公平警告,我现在才用 JavaScript/JQuery 编码几个月,我觉得这只是一些我还没有掌握的简单东西。围绕 SO 和网络有很多类似的问题,但我找到的答案似乎都不适合我。

我在 <head> 中引用了一些外部 JS 文件我的 html 文件的元素...

<head>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js"></script>
<script type="javascript" src="globalVars.js"></script>
<script type="javascript" src="gatherInfo.js"></script>
</head>

我存储在 globalVars.js 中的变量工作正常。我可以毫无问题地访问它们。但是,我存储在 GatherInfo.js 中的函数显示为 Uncaught ReferenceError: functionName is not defined在浏览器(Chrome 和 Firefox)的控制台中。

gatherInfo.js 文件只是我用来从服务器收集/解析数据的一组函数。例如,这是 GatherInfo.js 文件中的第一个函数...

var getAuthInfo = function() {
authInfo = $.ajax({
type: 'POST',
url: '/api/auth',
data: {"type": "normal", "username": loginName, "password": loginPassword},
success: setAuthToken,
error: authFail,
dataType: 'json',
async: true
});
};

如果我将函数从gatherInfo.js文件中移出,并将它们直接放入html文件中,在<body>中元素,在 <script> 内元素,它们工作正常。

我愿意发布我尝试过的所有内容,但这会将其变成一个相当冗长的问题...所以请告诉我是否有任何其他信息有帮助。

编辑: @Derek 这会让人感到困惑,所以请耐心等待......我觉得我在这里遗漏了一些东西。

这是我的外部 JS 文件的文件大小; gatherInfo.js = 4.4KB globalVars.js = 611B

现在,这是我在每次加载尝试时在 Chrome 开发工具的网络选项卡中看到的内容。(注意:每次尝试时我都会使用“清空缓存并硬重新加载”加载页面)

我的 src 属性设置如下 src="/globalVars.js"src="/gatherInfo.js" ...网络选项卡显示正在获取的文件,但是每个正在获取的文件的大小是 1.5KB,这当然不匹配。

现在,我的 src 属性设置没有前导 / ,像这样src="globalVars.js"src="gatherInfo.js" ...正在获取的globalVars.js 文件为912B,正在获取的gatherInfo.js 文件为4.7KB。假设稍大的文件大小只是数据包开销,看起来现在至少可以获取正确的文件了。函数调用仍报告为 not defined不过。

从这里我开始变得非常困惑......如果我将 src 属性更改为无意义/不存在的内容,就像这样 src="/dub/mud/fub/globalVars.js" ...它仍然显示它已成功获取文件,但它们的大小又回到了 1.5KB...所以显然不是正确的文件。但它不会返回 404 not found。

更进一步,如果我将 src 属性设置为一个不存在的文件名 src="fubar.js" ...它将返回 404 未找到错误。

我不知道为什么它的行为就像是在获取 globalVars.js 和 GatherInfo.js,即使我给它一个完全不正确的路径,但它会在不存在的文件上返回 404。

编辑:我继续设置了所有 3 个文件的要点。

https://gist.github.com/Eschin/317dc67a50a1297393d0

正如你所看到的,在overview.html中,我在正文中注释掉了所有JS函数...如果我取消注释它们,它们就可以正常工作。它们在移动到 GatherInfo.js 文件时会中断,并通过脚本标记进行引用。

最佳答案

我只是猜测您遇到的问题,但是如果您的函数包含在 IIFE 中,使用 var 不会使这些变量成为全局变量。

我认为最好的想法是为您的代码添加一个全局命名空间。每个文件应具有以下模板代码:

(function(){

if ( !window.myNamespace ) {
window.myNamespace = {};
}

myNamespace.function01 = function(){ /* add code here */ };
myNamespace.function02 = function(){ /* add code here */ };

})();

在您的情况下,使用 getAuthInfo 而不是 function01 等...然后当您调用函数时,请确保包含该命名空间。例如:

myNamespace.getAuthInfo();

关于使用 &lt;script&gt; 标记从外部 JS 文件引用的 JavaScript 函数报告为 "not defined",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34055657/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com