$(文件).ajaxstart没有开火

soo*_*oks 4 ajax jquery flickr

我有两个函数可以进行$ .getJSON调用 - 一个查看存储在服务器上的JSON,另一个调用Flickr.

我有这个:

$(document).ajaxStart(function(){ 
        alert('requeststart');
        //$('#loading').show(); 
    });
Run Code Online (Sandbox Code Playgroud)

当使用某个给定路径调用$ .getJSON时,它会起作用,但是当$ .getJSON调用Flickr时它不会发出警报.Flickr调用工作,并且所有内容都按原样加载...但它不会触发ajaxStart.(我正在使用ajaxStart和ajaxStop来显示loading-gif)

有任何想法吗?

这是调用Flickr的函数:

$('#submit').on("click", function (evt) {
    evt.preventDefault();
    var tag = $('input').val();
    if (tag == "") {
        alert("please enter a tag");
    }
    else {
      $.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?jsoncallback=?",{tags: tag, tagmode: "any", format: "json" },
      function(data) {
        $.each(data.items, function(i,item){
            var name = names[index];
            $("#" + name).empty();
            $('<img src="' + item.media.m.replace("_m.jpg", ".jpg") + '" />').appendTo("#" + name);
            $('<a href="' + item.link + '"> ' + item.title + '</a>').appendTo("#" + name );
            index ++;
            if (i==5) { 
                index = 0;
                }       
        });
      });
    }
});
Run Code Online (Sandbox Code Playgroud)

ste*_*ewe 6

如果jQuery 内部使用该对象,则jQuery仅触发这些事件(ajaxStartajaxStop)XMLHttpRequest.

但是,如果使用回调参数(JSONP)从不同的域请求数据,则jQuery不会使用XMLHttpRequest,而是通过插入<script>标记来实现.

这就是事件未被解雇的原因.


作为一种解决方法,您可以在$.getJSON调用之前启动加载动画,并在function(data) {..块内停止它.