$q.when(value);
$q.when() 用于将一个值(同步或异步)统一包装为 $q Promise 对象。

其本质目标是:
屏蔽同步值与异步 Promise 的差异,使调用方始终以 Promise 的方式进行处理。
value 可以是以下任意一种:
| 参数类型 | 行为 |
|---|---|
| 普通值(number、string、object 等) | 立即 resolve |
$q Promise | 直接返回(或状态跟随) |
thenable 对象(含 then 方法) | 按 Promise 规则解析 |
| 原生 ES6 Promise | 自动桥接为 $q Promise |
$q.when(...) → Promise
返回的是一个 $q Promise 对象,其状态由传入参数决定。
$q.when(100).then(function (value) {
console.log(value); // 100
});
fulfilledvar p = $q.defer().promise;
$q.when(p).then(function (value) {
console.log(value);
});
p.then(...)var thenable = {
then: function (resolve, reject) {
resolve('ok');
}
};
$q.when(thenable).then(function (value) {
console.log(value); // ok
});
$q.when() 会调用其 then 方法var nativePromise = Promise.resolve('hello');
$q.when(nativePromise).then(function (value) {
console.log(value); // hello
});
$q 会监听原生 Promise 的结果$digest在 AngularJS 1.4+ 版本中:
$q.when(value) === $q.resolve(value)
$q.resolve() 是语义更清晰的新 API$q.when() 为历史兼容方法$q.resolve()$q.when() 仍然完全可用$q.when(value).then(callback);
callback 永远是异步执行$digest 环境中| 对比项 | $q.when() | Promise.resolve() |
|---|---|---|
触发 $digest | 是 | 否 |
| Angular 视图更新 | 自动 | 需 $apply |
| 框架集成 | 深度 | 无 |
function getConfig() {
if (cache) {
return $q.when(cache);
}
return $http.get('/config').then(function (res) {
return res.data;
});
}
调用方:
getConfig().then(function (config) {
// 不关心是缓存还是网络
});
✅ 这是 $q.when() 最重要、最典型的用途
function normalize(value) {
return $q.when(value).then(function (v) {
return v.trim();
});
}
function wrapThirdParty(promise) {
return $q.when(promise);
}
确保:
$q.all([
$q.when(1),
$http.get('/api'),
maybePromise
]).then(function (results) {
console.log(results);
});
| 维度 | $q.when() | $q.defer() |
|---|---|---|
| 是否创建新 Promise | 是(轻量) | 是(完整) |
| 是否控制 resolve | 否 | 是 |
| 适用场景 | 包装、统一接口 | 主动控制异步流程 |
| 推荐程度 | 高 | 谨慎使用 |
能用
$q.when()的地方,通常不应使用$q.defer()
❌ 错误认知
✔️ 实际上始终异步
// 不推荐 return $q.when(flag ? value1 : value2);
可读性不佳,应合理拆分逻辑。
$q.when(value).then(function () {
throw new Error('error');
}).catch(function (e) {
console.error(e);
});
throw 会自动转为 reject$q.when() 的本质可以概括为一句话:
将一切“可能是异步的东西”,统一为一个可控、可组合、可追踪的
$qPromise。
其工程价值体现在:
到此这篇关于AngularJS中$q.when()的用法的文章就介绍到这了,更多相关AngularJS $q.when()用法内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!