0

我正在研究向其他 jQuery 回调提供数据的函数。问题是我还没有让它工作。当我将 fetchdata() 函数的内容直接放入 .click 回调时,它可以工作,但我需要一个单独的通用函数,以便将来可以将它与多个不同的回调一起使用。谁能指出我在这里做错了什么?似乎 fetchdata() 函数中的循环中断并且没有返回值。

    function fetchdata(){
        var html;
        $.ajax({
            url:'/test.php', 
            data:{ action: 'fetch-data' },
            dataType:'json',
            async: false,
            success: function(data){
                var entries = [];
                $.each(data, function(id, val){
                    entries.push(val.sample);
                });
                var html = entries.join('');
            }
        });
        return html;
    }
    $(document).on('click', 'a.btn.execute', function(e) {
        e.preventDefault();
        var html =  fetchdata();
        $('div#container').html(html);
    });

PS:我为上面的演示修改了我的代码,问题应该仍然存在。

4

1 回答 1

2

发生这种情况是因为您var html = entries.join('');进入了与您之前的 html 变量重叠的成功回调。只是html = entries.join('');会工作。但请不要真的使用async: false,因为它已经过时了

这是一个更好的解决方案:

function fetchdata(callback){
    $.ajax({
        url:'/test.php', 
        data:{ action: 'fetch-data' },
        dataType:'json',
        success: function(data){
            var entries = [];
            $.each(data, function(id, val){
                entries.push(val.sample);
            });
            var html = entries.join('');
            callback(html);
        }
    });
}
$(document).on('click', 'a.btn.execute', function(e) {
    e.preventDefault();
    fetchdata(function(html){
      $('div#container').html(html);
    });
});
于 2012-11-11T21:11:18.050 回答