首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在jQuery中使用getJSON函数时回调函数不起作用

在jQuery中使用getJSON函数时回调函数不起作用
EN

Stack Overflow用户
提问于 2009-04-20 22:36:59
回答 7查看 20.8K关注 0票数 18

我正在尝试使用jQuery中的getJSON函数来导入一些数据并触发回调函数。回调函数没有运行。但是,如果我用get函数做同样的事情,它会工作得很好。奇怪的是,即使当我传递"json“作为类型时,它也能与get函数一起工作。为什么会发生这种情况?我在Firefox3和IE7中测试了以下文件:

代码语言:javascript
复制
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html><head>
<meta http-equiv='Content-Type' content='text/html; charset=UTF-8'>
<title>ajax test</title>
<script type="text/javascript" src="/jquery-1.3.2.min.js"></script>
</head>
<body>
<input type="button" id="test1" value="get">
<input type="button" id="test2" value="getJSON">
<input type="button" id="test3" value="get with json type">
<script type="text/javascript">
$("#test1").click(function() {
    $.get("index.html",
        function(response) {
            alert('hi');
            //works
        }
    )
});

$("#test2").click(function() {
    $.getJSON("index.html",
        function(response) {
            alert('hi');
            //doesn't work
        }
    )
});

$("#test3").click(function() {
    $.get("index.html",
        function(response) {
            alert('hi');
            //works
        },
        "json"
    )
});
</script>
</body></html>

无论我访问什么URL,只要它在同一个域上,似乎都会发生这种情况。我试着传递了一些数据,但没有什么不同。

当然,我可以通过使用get函数来解决这个问题,就像我在第三个测试函数中所做的那样,但我仍然很好奇为什么会发生这种情况。

我知道这里有一个similar question,但它没有回答我的问题。

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/770381

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档