草庐IT

Promise方法

全部标签

javascript - 我如何解决 AngularJS 单元测试中的 promise

我正在使用基本的karma/jasmine设置来测试我的Angular代码。这是我的测试:var$controllerConstructor,ctr,mockSuperheroData,scope,deferred,q;describe('maincontroller',function(){var$controllerConstructor,ctr,mockSuperheroData,scope,deferred,q;beforeEach(inject(function($controller,$rootScope,$q){scope=$rootScope.$new();$contr

javascript - 检查对象在 JavaScript 中是否可序列化的可靠方法

是否有已知的方法或库已经有帮助程序来评估一个对象在JavaScript中是否可序列化?我尝试了以下方法,但它没有涵盖原型(prototype)属性,因此它提供了误报:_.isEqual(obj,JSON.parse(JSON.stringify(obj))还有另一个lodash函数可能会让我更接近真相,_.isPlainObject。然而,当_.isPlainObject(newMyClass())返回false时,_.isPlainObject({x:newMyClass()})返回true,因此需要递归应用。在我自己冒险之前,有没有人知道一种已经可靠的方法来检查JSON.parse

javascript - 试图监视(Jasmine)Array.prototype 方法导致堆栈溢出

这很奇怪。将testemrunner与jasmine2一起使用并执行以下规范(尽管它正确地标记了没有期望):describe('Spyingonarray.prototypemethods',function(){it('shouldworkthisway',function(){spyOn(Array.prototype,'push').and.callThrough();//expect(1).toBe(1);});});但是,添加一个expect(任何expect!)它会导致堆栈溢出,并在testem控制台中显示以下消息:RangeError:超出最大调用堆栈大小。在http:/

javascript - 取消 promise 链?

我链接了一系列的promise:this.getData.then(this.getMoreData).then(this.getEvenMoreData);在某些时候,用户可能会决定取消请求并请求其他内容。如何取消链的传播? 最佳答案 您必须检查每个链接方法内的状态(是否应取消):varuserRequestedCancel=false;this.getData().then(function(){if(userRequestedCancel){returnPromise.reject('usercancelled');}retu

javascript - 在 ES6 + babel 中使用 bluebird promise 导入类(构造函数)

假设我创建了一个node.js库lib.jsexportclassC{constructor(value,callback){callback(false,`Hello${value}`);}task(value,callback){callback(false,"returned"+value);}}重要的部分是类的构造函数需要接受回调,因为它处理数据库连接和文件I/O。如果我现在导入并使用库回调样式,一切都很好(请参阅下面的c1)。我真的很想promise我使用它的库,使对象构造更方便(实际上它是一大堆类和方法)。但是,我找不到在promise-safe中正确地new类的方法。im

javascript - 从 react 组件的数组类型状态属性中弹出的正确方法?

假设我有一个像这样的react组件:varMyComponent=React.createClass({getInitialState:function(){return{myStack:[]};},...pop:function(a){//anyconcise,elegantwaytopopfromarraytypestate?}}也许我可以写pop:function(){varclone=_.clone(this.state.myStack);clone.pop();this.setState({myStack:clone});}但它看起来很丑...我知道它可以工作,但是当我编写这

javascript - for循环(每次迭代都会产生一个 promise )完成后如何返回单个 promise ?

我的promise返回代码有问题,我有一个函数getTagQuotes,它包含一个for循环,它可以多次调用API以将数据返回到数组中。我的代码是如何开始的://Iftherearetags,thenwaitforpromisehere:if(tags.length>0){//SettingpromisevartogetTagQuotes:varpromise=getTagQuotes(tags).then(function(){console.log('promise=',promise);//Thisarrayshouldcontain1-3tags:console.log('tw

javascript - React 组件中 "shouldComponentUpdate"生命周期方法的默认实现是什么

shouldComponentUpdate()方法的自定义实现不需要作为React组件生命周期的一部分。我知道这是一个bool函数,它决定是否在组件props和state发生变化时调用render(),并且有mixins像PureRenderMixin它实现了shouldComponentUpdate()如果没有提供自定义实现或混合。默认的实现和行为是什么? 最佳答案 从Reactv0.13和v0.14开始,默认实现等于null并且按照这个逻辑:varshouldUpdate=this._pendingForceUpdate||!i

javascript - 使用 ES6 模块的 TypeScript 的最佳方法是什么?

我正在开始一个新的Web项目并尝试使用TypeScript,主要作为ES6转译器,但也有类型检查的额外好处,特别是对于现有的库,例如jQuery结合了DefinitelyTyped类型定义。从最新版本开始,TypeScript既支持自己的内部模块,也支持ES6模块,后者称为“外部”模块。因为ES6比TypeScript更标准,所以我打算使用ES6/外部模块而不是传统/内部TypeScript模块。我在多个文件/模块中定义了自己的代码,但我希望构建生成一个我可以从浏览器加载的.js文件。问题是,据我所知,TypeScript在使用自己的模块格式时只能生成单个输出文件。如果我尝试使用ES6

javascript - Node JS Async Promise.All 问题

我正在尝试对从数据库中获取的列表中的一堆项目执行异步例程,但我无法理解promise.all的工作原理和作用。这是我现在使用的代码:/***Queuesuppriceupdates*/functionupdatePrices(){console.log("~~~NowupdatingalllistingpricesfromAmazonAPI~~~");//Grabsthelistingsfromthedatabase,thispartworksfinefetchListings().then(function(listings){//Createsanarrayofpromisesfr