0

我是一个 javascript 菜鸟,我不明白为什么会这样:

$().load('/my/url/', {my:data, more:data}, jsFunc());

function jsFunc()
{
    $("#myid").val("yep");
}

但不是这个:

$().load('/my/url/', {my:data, more:data}, function() {jsFunc()});

function jsFunc()
{
    $("#myid").val("yep");
}

我尝试了 $.ajax 而不是 $.load ,结果相同。我会将响应数据传递给 jsFunc(),这就是为什么我需要在函数内部使用 jsFunc()。我确定这很简单,我只是对 javascript 不是很有经验。谢谢。

再次感谢所有帮助。我决定使用 $.post ,因为它最适合这种情况,但现在我遇到了响应数据问题。我的代码如下所示:

$.post('/my/url/', {my:data, more:data}, function(data) {
    var strung = JSON.stringify(data)
    var parse = jQuery.parseJSON(strung)
    console.log(parse.some);}, 'json');

我正在登录控制台以查看现在返回的内容,当我看到记录的正确值时,我将添加回调。我从 jQuery api 页面获得的过程,但它只会记录undefined. 当我更改parse.someparse控制台日志将显示对象,我可以选择一个元素并查看正确的键:值对。任何帮助都会很甜蜜。

4

3 回答 3

4

两者都不起作用。第一个似乎有效,因为您jsFunc立即调用该函数,它不会等待任何响应。

如果您使用$()并使用该load方法创建一个空的 jQuery 对象,它不会调用服务器,因为没有可以放置结果的元素。

要指定回调函数,您可以使用函数的名称:

$('#someElement').load('/my/url/', {my:data, more:data}, jsFunc);

或函数表达式:

$('#someElement').load('/my/url/', {my:data, more:data}, function() { jsFunc(); });
于 2013-02-05T15:09:37.130 回答
0

第一个代码块将简单地调用 jsFunc() 并将结果作为参数返回给 load(..) 方法,这很奇怪,因为该参数应该是在加载完成时触发的回调函数,但这有效吗?回调语法更符合第二个示例(我相信您所说的那个不起作用)。

于 2013-02-05T15:05:10.797 回答
0

回答我的第二部分:

我返回的 JSON 数据由许多对象组成,因此我必须指定索引和键来获取要返回的值。

于 2013-02-06T15:24:08.457 回答