草庐IT

Promise方法

全部标签

javascript - 是否有任何解决方法可以重新抛出异常并保留 Javascript 中的堆栈跟踪?

我知道Chrome有一个knownbug在Javascript中重新抛出异常时不保留堆栈跟踪。我在Chrome中运行了以下代码:try{try{runCodeThatMayThrowAnException();}catch(e){//I'mhandingtheexceptionhere(displayinganicemessageorwhatever)//NowIwanttorethrowtheexceptionthrow(e);}}catch(e){//Thestacktracewaslosthere:(}有什么方法可以保留堆栈跟踪吗?也许是一个jQuery插件?任何解决方法或想法?

javascript - sublime-jslint:有什么方法可以忽略特定的代码部分吗?

我有一大堆JS意大利面条,急需好好擦洗。我已经通过packageControl配置sublimetext2以使用sublime-jslint,并且我已经将必要的命令行开关传递给jslint4java-2.0.1所以它知道如何发挥它的魔力。问题是,这些文件包含一些粘贴的第三方代码。我无法将此代码移出文件,因为它是时间关键的,需要在其他任何事情之前加载。我查看了jslint4java文档,但找不到让它忽略脚本特定部分的方法。我搜索了整个网站,我能找到的关于忽略代码区域的唯一内容是jslint网络版本。所以,我的问题是:有没有办法让它忽略javascript文件的特定区域?如果我能以某种方式

JavaScript click() 方法仅在 Chrome 扩展程序中有效一次

我正在尝试在Chrome扩展程序中下载多个文件。以下代码创建一个指向文件的虚拟链接,然后触发下载文件的.click()事件。问题是只有第一个.click()事件触发下载。随后的.click()事件将被忽略。这里是ma​​nifest.json:{"name":"SimpleFileDownloader","version":"0.1","permissions":["contextMenus","http://*/"],"background":{"persistent":false,"scripts":["sample.js"]},"content_security_policy":

javascript - 哪种方法更好 : function. apply(<this>, args) 或具有接受 <this> 作为参数的函数?

假设我有一个这样定义的函数A:functionA=function(myObject,someParams){myObject.save_some_data=someParams;myObject.processed=true;}然后我可以调用它并传递一个对象作为functionA(someObject,someParams)进行处理。不过,我可以用apply()转换这个例子:functionA=function(someParams){this.save_some_data=someParams;this.processed=true;}functionA.apply(someObj

javascript - 检查 IE 的快速伪真方法?

我读了一篇关于的文章TestforInternetExplorerinJavaScript表示快速测试是:varisMSIE=/*@cc_on!@*/0;if(isMSIE){//doIE-specificthings}else{//dononIE-specificthings}但其中一个comments展示了另一种方式:(我不得不说,它有效)if(-[1,]){//dononIE-specificthings}else{//doIE-specificthings}所以我问:-[1,]有什么特别之处以至于IE无法识别而其他人可以识别它?附:找到另一个快速伪真技巧IE='\v'=='v'

javascript - Q promise 中的并发限制 - Node

有没有什么方法可以使用Qpromises库来限制promise的并发?这个问题有点相关HowcanIlimitQpromiseconcurrency?但问题是我正在尝试做这样的事情:for(vari=0;i实际用例是:从数据库中获取帖子循环数据库中的每个帖子,如posts.forEach(function(post){}对每个帖子执行任务1、任务2、任务3(检索社交计数器、检索评论计数等)在数据库中保存新的帖子数据。但问题是Node同时执行所有帖子的所有任务,比如同时向facebook询问500个帖子的“喜欢计数”。我如何限制Q.all()一次只有2个帖子在执行它们的任务?或者还有哪些

javascript - 在循环中链接嵌套的 promise

我对promises有点陌生,并且坚持以下练习。我有一组值,我想对每个值执行一个异步调用。在回调中,我想对第一次调用的结果执行另一个调用。基本上,我的挫败感在于:执行顺序应该是'1x2x3x'但是顺序是'123xxx'换句话说,当第一个promise的子/嵌套promise尚未完成时,循环已经进入下一次迭代。varvalues=["1","2","3"];functiondo(val){vardeferred=Q.defer();asyncCall(val).then(function(response){console.log(val);asyncCall(response).the

javascript - 使用 Bluebird promise bcrypt-nodejs

我正在使用NodeJS,bcrypt-nodejs(https://github.com/shaneGirish/bcrypt-nodejs)和Bluebird用于promises。想出了这段代码,并想知道是否有更好的方法来做同样的事情。我有模块:varPromise=require("bluebird"),bcrypt=Promise.promisifyAll(require('bcrypt-nodejs'));//....[someothecodehere]Users.prototype.setPassword=function(user){returnbcrypt.genSalt

javascript - 当我不使用 Promise 的 "then"函数时,是否有任何(负面)副作用?

我有一个返回Promise的函数。现在,有时消费者在该Promise上使用“then”函数是有意义的。但有时消费者根本不关心Promise何时解析,也不关心结果-换句话说,同样的函数也应该能够以“即发即弃”的方式调用。所以我想要这两种使用场景:func().then(...);//processPromisefunc();//"fireandforget"这显然有效,但我想知道这是否被视为“不良做法”,特别是这种使用模式是否会产生任何不良副作用,即。导致内存泄漏?现在我正在使用bluebird,但如果有任何不同,我会考虑切换到原生Promises。 最佳答案

javascript - CasperJS/PhantomJS ES6 Promise Polyfill

我目前正在尝试使用PhantomJS和CasperJS来制作端到端测试。我遇到的是PhantomJS缺乏promise的情况。目前我们的项目实现了它们。该应用程序仅在原生支持promises的GoogleChrome中使用。在运行我的测试时我收到错误:错误:ReferenceError:找不到变量:Promise这似乎是因为PhantomJS中当前版本的Webkit不支持promise。我意识到SlimerJS确实通过Gecko获得了这种支持,但是我们的应用程序在Chrome中运行,因此我希望在Webkit中进行测试。我一直在努力解决的问题是将ES6promisepolyfill注入(