jjzjj

javascript - 扩展 `Promise` 并更改 `then` 签名

我想延长Promise并更改then签名所以它的回调接收两个值。我尝试了不同的方法,其中两种已记录并经过测试here.遗憾的是,我遇到了各种错误,或者生成的类的行为不像Promise。方法一:WrappinganativePromiseexportclassMyWrappedPromise{constructor(data){this.data=data;this.promise=newPromise(evaluate.bind(data));}then(callback){this.promise.then(()=>callback(this.data,ADDITIONAL_DATA

javascript - 条件 .then 执行

如何有条件地跳过promise而不做任何事情。我创建了一个嵌套的promise,我有7个.then's。但有条件地,我需要跳过几个.then并且在那个block中什么都不做,如何实现这个?我的完整代码:constadmin=require('firebase-admin');constrp=require('request-promise');module.exports=function(req,res){constphone=String(req.body.phone).replace(/[^\d]/g,'');constamount=parseInt(req.body.amoun

javascript - 如何将回调样本转换为延迟对象?

我有一个接受回调函数的函数,我在其中将数据传回。可以将其转换为延迟对象以便更好地练习吗?这是我得到的:varchapters;vargetChapters=function(fnLoad){//CACHEDATAIFAPPLICABLEif(!chapters){//CALLJSONDATAVIAAJAX$.getJSON('/chapters.txt').done(function(json){//STOREDATAINLOCALSTORAGEchapters=Lawnchair(function(){this.save(json,function(data){//CALLCALLB

javascript - 在 promise 链中访问先前履行的 promise 结果

这个问题在这里已经有了答案:HowdoIaccesspreviouspromiseresultsina.then()chain?(17个答案)关闭7年前。在使用promises编码时,访问promises链中很久以前的数据的正确模式是什么?例如:do_A.then(do_B).then(do_C).then(do_D).then(do_E_WithTheDataComingFrom_A_And_C_OnlyWhen_D_IsSuccesfullyCompleted)我当前的解决方案:通过链传递单个JSON结构,并让每个步骤填充它。对此有何看法?

javascript - 有条件的 promise

在我的脚本中,我需要检索字典以将编码值转换为名称:$.ajax({//retrievedictionary}).done(function(dictionary){//convertencodedvaluesintonames}).done(function(){//runmyapplication});但是,有时字典已经被另一个应用程序加载,在这种情况下我不需要ajax调用:if(dictionary){//convertencodedvaluesintonames//runmyapplication}else{$.ajax({//retrievedictionary}).done(

javascript - 如何避免这种异步惰性模式?

很多时候,我需要在Javascript中编写这样一个延迟异步加载:if(myvar!=undefined){doSomeTreatment(myvar)}else{loadMyVarAsynchronously().then(function(value){myvar=valuedoSomeTreatment(myvar)})}在这里,myvar是散列的某个属性,而不是局部变量。loadMyVarAsynchronously异步加载myvar的值(例如,使用Promise或JQueryDeferred)是否有一种模式可以避免在此代码中将以下行写两次?doSomeTreatment(my

javascript - promise findOneAsync 变量 = {"isFulfilled":false ,"isRejected":false}?

利用Bluebird来PromisfyMongoose,我有一个Promise.map(带有一系列if/else的函数,用于遍历数组以查看是否存在引用文档,否则创建一个..将findOneAsync的产品分配给一个变量,然后将“variable._id”分配给正在制作的新文档(主要promise),控制台记录{"isFulfilled":false,"isRejected":假的这是一个片段:for(i=0;i这是一个日志:existingItem:{"isFulfilled":false,"isRejected":false}existingItem._id:undefined为什么

javascript - 如何将这个延迟风格的 promise 转换为 ES6 风格的 promise

请参阅新手错误#4:在NolanLawson中使用“延迟”的文章:Wehaveaproblemwithpromises(顺便说一句很棒的帖子!),我尽量不再使用延迟风格的promise。最近我遇到了一个实际的例子,我不知道如何不以延迟的方式编码,所以我需要一些建议。这是一个例子,一个Angular工厂:functionConfirmModal($q,$modal){return{showModal:function_showModal(options){var_modal=$modal(options)vardeferred=$q.defer()_modalScope.confirm=

javascript - 为什么在解析父状态 promise 之前执行子状态解析函数

我正在使用ui-routerv0.2.13。Thispage指出:Allresolvesononestatewillberesolvedbeforemovingontothenextstate,eveniftheyaren'tinjectedintothatchild还有更多Allresolvesforallthestatesbeingenteredaretriggeredandresolvesdbeforethetransitionwillenteranystates(regardlessoftheresolvebeinginjectedsomewhere)但是,在我的例子中,子状态

JavaScript:将同步代码调整为异步,以支持 IE8?

我正在处理一个数据密集型网站,我需要支持IE8。我在IE8中收到一些“运行缓慢的脚本”错误,因此我正在调整我的代码以在旧浏览器的循环期间定期暂停。这是我当前的代码:combineData:function(xData,yData,values){varcombinedData=this.combineDatasets(xData,yData,values.x,values.x_val);combinedData=this.calculateRatiosForData(combinedData);//variousotherdataoperations,thencontinuetoset