⚡ 编程实验室🏗️ HTML🎨 CSS⚡ JavaScript🐍 Python🗄️ SQL☕ Java⚛️ React💚 Vue🟢 Node.js⚙️ C语言🐘 PHP🐹 Go🔷 TypeScript🐬 MySQL🔧 C++🎯 C#🦀 Rust🅱️ Bootstrap💡 jQuery🎸 Django🍃 MongoDB👗 Sass🎪 Kotlin📊 R语言📋 XML📊 Excel🐘 PostgreSQL🐳 Docker🅰️ Angular🎮 游戏🏠 网站首页

jQuery Deferred 异步控制

理解jQuery的Deferred/Promise异步编程模式 · 难度:高级 · +15XP

jQuery Deferred

Deferred是jQuery的异步编程方案,早于ES6 Promise。

创建Deferred

function asyncTask() {
    var dfd = $.Deferred();
    setTimeout(function() {
        dfd.resolve('成功了');  // 或 dfd.reject('失败');
    }, 1000);
    return dfd.promise();
}

asyncTask()
    .done(function(msg) { console.log(msg); })
    .fail(function(err) { console.error(err); });

$.when() 并行等待

$.when(
    $.get('/api/users'),
    $.get('/api/posts')
).done(function(usersResp, postsResp) {
    var users = usersResp[0];
    var posts = postsResp[0];
    console.log(users, posts);
});

Deferred vs Promise

对比DeferredES6 Promise
标准jQuery专有JS标准
创建$.Deferred()new Promise()
成功.resolve()resolve()
失败.reject()reject()

💡 练习

用Deferred包装setTimeout,然后用$.when并行执行两个延迟任务。
Ctrl+Enter
🚀 升级VIP
解锁全部课程+AI助手

🏆 学习排行

加载中...

📊 统计

📖 55 篇
0 完成
🔥 0