• jQuery:多个AJAX/JSON请求对应单个回调并行加载


    因为我们使用jQuery,这意味着需要调用 jQuery.getScript 和 jQuery.getJSON 函数。 我知道这些函数都是异步执行(asyncronously)并且会延迟一段时间返回,所以我想知道是否有一种方式,使我可以使用单个回调,并行地加载它们,就像JS加载器 curljs 所做的那样。 很幸运! 通过jQuery.when, 我可以并发地加载两个请求,只执行一次回调!

    jQuery 脚本
    正如我提到的,下面是加载脚本和一个JSON资源的用例:

    $.when(
        $.getScript('/media/js/wiki-min.js?build=21eb633'), 
        $.getJSON('https://developer.mozilla.org/en-US/demos/feeds/json/featured/')
    ).then(function(a, b) {  // 或者也可以使用 ".done"
        // Yay, 加载完成,此处我们可以执行一些依赖操作。。。
    });

    当资源加载完成, 指定的 done 或者 then 回调会触发,因此可以知道请求已经完成。 每个请求返回的回调参数对象类型不同,因此上述请求可能返回如下信息:

    // 格式: [response, state, jqxhr], [response, state, jqxhr]
    ["(function(c){var e=c(".from-search-navigate");if(e…;if(j){g.apply(m,l)}}}})(window,document,jQuery);", "success", Object]
    [Array[15], "success", Object]

    如果还需要增加一个传统的AJAX XHR请求,比如说一个小部件模板,我们可以这样做:

    $.when(
        $.getScript('/media/js/wiki-min.js?build=21eb633'), 
        $.getJSON('https://developer.mozilla.org/en-US/demos/feeds/json/featured/'), 
        $.get('/')
    ).then(function(a, b, c) { 
        console.log(a, b, c); 
    });

    Dojo Toolkit很早就有此类功能了,但jQuery也可以这么做我还是相当振奋的。 对于现在的开发,多个不同步且返回先后顺序也不确定的请求共享同一个回调是很自然的需求,所以jQuery绝对是与时俱进的!

  • 相关阅读:
    使用Spring Boot来加速Java web项目的开发
    Spring IOC的理解
    CentOS查看系统信息-CentOS查看命令
    mybatis传递Map和List集合示例
    java文件读写工具类
    MongoDB数据库操作
    linux中给PHP安装mongodb的扩展
    深度学习与计算机视觉系列(2)_图像分类与KNN
    深度学习与计算机视觉系列(3)_线性SVM与SoftMax分类器
    深度学习与计算机视觉系列(6)_神经网络结构与神经元激励函数
  • 原文地址:https://www.cnblogs.com/colder/p/5466307.html
Copyright © 2020-2023  润新知