V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
xujinkai
V2EX  ›  JavaScript

JS 如何保证 ajax 顺序,写了个小东西

  •  
  •   xujinkai · 2017-03-19 12:14:57 +08:00 · 3673 次点击
    这是一个创建于 2864 天前的主题,其中的信息可能已经有所发展或是发生改变。

    非前端,轻吐槽- -

    自己做 spa 弄的,想要先判断是不是登录,如果登录的话,再去加载别的信息。

    以下是示例,效果就是先获取 session ,如果登录的话,再运行 callback 。

    $.get('/session', (data)=>{
    	if(data.login) loading.done('login');
    }
    
    //然后在别的文件里
    loading.run_after(callback, 'login');
    

    callback 会在 login 后才执行,第二个参数也可以是 Array

    不知会不会有用,本体很短,地址在这里 (忽略这个仓库,还没做完...)

    12 条回复    2017-03-20 09:06:40 +08:00
    guokeke
        1
    guokeke  
       2017-03-19 12:19:52 +08:00
    我觉得你直接回掉就好。

    如果你觉得不优雅可以看看 Promise.
    jarlyyn
        2
    jarlyyn  
       2017-03-19 12:21:21 +08:00
    楼主看过 async.js 吗?
    think2011
        3
    think2011  
       2017-03-19 12:31:29 +08:00
    目测楼主用的是 jquery ,你可以试试这样

    ```js
    function fetchSession() {
    // 防止多次请求
    if(window.SESSION) return $.when(window.SESSION)

    return $.get('/session', (data) => {
    window.SESSION = data.login
    return data.login
    }
    }

    fetchSession().then( data => {
    // do sth
    })


    fetchSession().then( data => {
    // do sth2
    })
    ```
    oott123
        4
    oott123  
       2017-03-19 12:36:17 +08:00
    挺不错的小轮子。不过 loading.run_after 的两个参数如果对调的话应该会更好看。

    当然了,从实用和工程的角度来说,还是看看 Promise 比较好……
    loading
        5
    loading  
       2017-03-19 12:51:43 +08:00
    恩,对我这个程序写着玩的销售很有用。

    感谢分享!
    xujinkai
        6
    xujinkai  
    OP
       2017-03-19 13:24:08 +08:00
    @loading 你的名字
    @think2011 感谢分享
    @jarlyyn 没...去看看
    @guokeke @oott123
    我知道 promise ,不过 promise 得把函数都改造成 promise 吧,而且链式调用都得写一起,就造了这个,作为小项目,啥都不用改,直接传函数就行。
    oott123
        7
    oott123  
       2017-03-19 13:31:27 +08:00   ❤️ 1
    完全不用改别的地方。就你这个需求而言,可以直接用 promise 写好,和你的几乎等价:

    https://gist.github.com/a1001fdfd0d33d8711f5b7aa12f666fe
    oott123
        8
    oott123  
       2017-03-19 13:34:19 +08:00
    Promise 并不一定要求你在所有地方都用 Promise ,这是一个误解。

    你可以把 Promise 和回调等异步手段混用,没有任何问题。只是从实践角度而言,不推荐这么写(主要是维护起来很乱)。

    作为小项目,更应该尝试使用新鲜有趣的设计、保持快速迭代。
    xujinkai
        9
    xujinkai  
    OP
       2017-03-19 13:35:10 +08:00
    @oott123 学习了 非常感谢
    jzz7280
        10
    jzz7280  
       2017-03-19 16:18:01 +08:00
    建议看看"你不知道的 javascript"中卷
    iyangyuan
        11
    iyangyuan  
       2017-03-19 19:05:49 +08:00 via iPhone
    有些顺序也可以巧妙的通过 js 单线程模型实现
    chaegumi
        12
    chaegumi  
       2017-03-20 09:06:40 +08:00
    LABjs
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   6078 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 27ms · UTC 06:18 · PVG 14:18 · LAX 22:18 · JFK 01:18
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.