作者ZAbird (炸鸟)
看板Ajax
标题[问题] 同步变数接异步函数返回值
时间Sun Mar 12 05:54:36 2017
虽然这个问题有点蠢, 但是爬过相关文章都看不太懂. 目前是看到利用Promise
来解决, 但是找到的例子有点复杂不太能消化. 想请求大神帮忙.
举个最简单的例子 我今天想要做这样的事情:
var x = getValue();
function getValue(){
var temp;
setTimeout(function(){temp = 3}, 2000);
return temp
}
这时候因为执行返回时 temp 还没有被赋值, 所以x 会是undefined.
我该怎麽用promise 来让我确定拿到我要得值才返回给 x 接住呢.
或者有其他技术可以实现. 不好意思, 初学js. 请指点迷津, 谢谢!
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 75.109.208.14
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Ajax/M.1489269278.A.6D9.html
1F:→ dannypsnl: 不行啊,你setTimeout立刻返回,直到它操作完成才会执 03/12 07:00
2F:→ dannypsnl: 行,应该是把对X设值的动作移到setTimeout的callback里 03/12 07:00
3F:→ dannypsnl: 面才对 03/12 07:00
4F:→ ZAbird: 我只是用模拟的方式表达..实际上是要完成其他很多function 03/12 07:26
5F:→ ZAbird: 如果我把 var x 丢到setTimeout 里面 问题还是无解 03/12 07:27
6F:→ ZAbird: 我要的是在global 的地方接到这个值所以还要return回main 03/12 07:28
7F:→ ZAbird: 工作才算完成.. 03/12 07:28
8F:→ ZAbird: 我现在是已经用promise 解决了..但是对promise的用法观念 03/12 07:29
9F:→ ZAbird: 还非常模糊, 希望有人能藉由这个例子浅显的说明, 感激不尽 03/12 07:29
10F:推 Qiqi: getValue要写return new Primise(...) 03/12 11:43
11F:→ Qiqi: 然後就可以用x.then(...)去拿到值 03/12 11:44
12F:→ Qiqi: mdn有例子可以看 03/12 11:45
14F:推 Qiqi: x.then里面的function就是等promise里面有被resolve或reject 03/12 11:47
15F:→ Qiqi: 才会执行,这就是所谓的异步 03/12 11:47
16F:→ ZAbird: 理解.感谢你! 衍伸一个问题, 如果我第一个异步返回要给 03/12 12:21
17F:→ ZAbird: 让第二个异步来用 然後再返回去global, 这样我是要分别 03/12 12:22
18F:→ ZAbird: 在第一个函式跟第二个函式都写 return new Premise 03/12 12:22
19F:→ ZAbird: 然後让用第一个含式.then(function(){第二个函式}) 03/12 12:24
20F:→ ZAbird: 这样的写法吗?还是应该有更简洁的结构呢 03/12 12:25
21F:→ vincenter: 要更简洁要用async/await 03/12 14:54
22F:→ vincenter: 可以研究一下callback的进化史 03/12 14:54
23F:→ vincenter: callback->promise->generation/yield->async/await 03/12 14:55
24F:→ vincenter: ^应该是generator 03/12 14:56
25F:→ vincenter: 想了一下突然很疑惑,异步的值真的可以传到所谓的 03/12 16:02
26F:→ vincenter: global的地方吗? 03/12 16:02