gpt4 book ai didi

javascript - 这个 JavaScript 是如何工作的?

转载 作者:行者123 更新时间:2023-11-28 16:06:29 26 4
gpt4 key购买 nike

我是一个 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.some 更改为 parse 时,控制台日志将显示对象,我可以选择一个元素并查看正确的键:值对。任何帮助都会很甜蜜。

最佳答案

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

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

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

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

或函数表达式:

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

关于javascript - 这个 JavaScript 是如何工作的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14710396/

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