亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

javascript - 關于Promise,為何我這樣寫不能得到正確的執行順序?

瀏覽:117日期:2023-02-22 10:39:23

問題描述

$.ajax({ url: ’/latestNewsIndex’, type: ’get’, dataType: ’json’, timeout: 1000, success: function (data, status) {if (data.value.length == 0) { alert('暫時沒有更多新聞!');}else { f2(data.value);} }, fail: function (err, status) {alert(’暫時沒有更多新聞!’); }})function f2(news) { var promise = new Promise(function(resolve,reject) {pullUpAction(news);resolve(1); }); promise.then(function(id) { loaded()});}

通過ajax,然后調用f2(),可以實現先執行pullUpAction(news),結束后執行loaded()。可是如果直接執行否f2(),像下面:

f2(news);function f2(news) { var promise = new Promise(function(resolve,reject) {pullUpAction(news);resolve(1); }); promise.then(function(id) { loaded()});}

就不能實現Promise先后執行方法的效果,這是為什么呢?

問題解答

回答1:

test(’test’)function test (value) { let promise = new Promise(function (resolve, reject) { test1(value) resolve(1) }) promise.then(function (id) { console.log(’我后執行,我的值為:’ + id) })}function test1 (value) { console.log(value) window.setTimeout(function (value) { console.log(’我先執行,我的值為:’ + value) }, 10 * 1000)}

結果是javascript - 關于Promise,為何我這樣寫不能得到正確的執行順序?

在沒有設定時的時候是先執行的test1函數再執行promise對象成功時的返回.有可能的猜測就是你在使用ajax請求時,f2函數完成的時間剛好與ajax請求結束的時間一樣或者小于,所以你看到了你想要的執行結果,但是直接調用不通過ajax時則反應出了真實的反應時間。建議在這里pullUpAction調試看看以上為本人愚見,僅做參考

標簽: JavaScript
主站蜘蛛池模板: 中文字幕一区二区三区亚洲精品 | 狠狠做久久深爱婷婷97动漫 | 久久99久久精品国产只有 | 成人免费黄色网址 | 色综久久 | a毛片免费播放全部完整 | 欧美片欧美日韩国产综合片 | 国产在线综合一区二区三区 | 无遮挡一级毛片私人影院 | 久久这 | 在线视频亚洲一区 | 手机看片精品高清国产日韩 | 国产成人18| 特黄特级a级黄毛片免费观看多人 | 黄色理论视频 | 成人做爰在线视频 | 看中国毛片 | 日韩中文字幕在线看 | 日韩欧美色综合 | 91久久精品国产91久久性色也 | 欧美最爽乱淫视频播放黑人 | a级一级黄色片 | 99精品久久99久久久久久 | 精品久久久久久久久久久久久久久 | 欧美一区a | 国产区91| 亚洲精品久久玖玖玖玖 | 免费女人18毛片a级毛片视频 | 日本一区二区三区在线 视频 | 亚洲手机在线 | 成人精品第一区二区三区 | 久久久久久色 | 亚洲精品在线影院 | 美女视频全部免费 | 精品欧美一区二区三区四区 | 日本乱人伦在线观看免费 | 高清毛片免费看 | 日韩男人天堂 | 久久精品视频9 | 成 人 a v黄 色 | 国产成人精品视频一区二区不卡 |