使用NodejsQPromise库的.finally()和.done()语句有什么区别。比如这两者有什么区别?Q(...).then(...).finally();//orfin()Q(..).then().done(); 最佳答案 promise.done(onSuccess,onError)只允许您处理已解析的值。另一个好处是它不会暗示任何错误吞咽(就像promise.then()的情况一样),它保证任何涉及的异常都会被暴露。它还有效地结束了链条,并且不会返回任何进一步的promise。promise.finally(fn)用于
我有一些代码在一个Node程序的子进程中运行,如下所示:try{vardata=fs.readFileSync(urlPath,{"encoding":"utf8"});}catch(err){console.log("Errorreadingurlfile...");throwerr;}finally{console.log("Fileread!");vararray=data.split("\n");console.log("Found"+array.length+"urls");这段代码是从另一个Node程序调用的,它需要等到这个文件中的所有操作都完成。不幸的是,在执行final
我有一个简单的例子:varstr='{"test":1,}'try{JSON.parse(str);}catch(e){console.log(e)}结果:[SyntaxError:Unexpectedtoken}]如何打印所有错误信息?预期结果:undefined:1{"test":1,}^SyntaxError:Unexpectedtoken} 最佳答案 这会有所帮助:varx={asd:"asd",};try{JSON.parse(x);}catch(e){console.log("Error",e.stack);consol
我正在尝试编写一个程序来从s3获取一个zip文件,解压缩它,然后将其上传到S3。但是我发现了两个我无法捕捉到的异常。1.StreamContentLengthMismatch:流内容长度不匹配。收到980323883个字节,共5770104761个字节。这种情况不规律地发生。2.NoSuchKey:指定的键不存在。当我输入错误的键时会出现这种情况。当这两个异常发生时,这个程序就会崩溃。我想正确地捕捉和处理这两个异常。我想防止崩溃。constunzipUpload=()=>{returnnewPromise((resolve,reject)=>{letrStream=s3.getObje
在ES6中是否可以在严格模式下使用const在try{}中设置变量?'usestrict';constpath=require('path');try{constconfigPath=path.resolve(process.cwd(),config);}catch(error){//.....}console.log(configPath);由于configPath定义超出范围,因此无法进行lint。这似乎可行的唯一方法是:'usestrict';constpath=require('path');letconfigPath;try{configPath=path.resolve(p
我在node.js脚本上使用trycatch:try{}catch(err){console.log(err)}我得到这样的输出:{stack:[Getter/Setter],arguments:['undefined'],type:'called_non_callable',message:[Getter/Setter]}有没有一种简单的方法可以使信息更丰富?包括行号和函数名等? 最佳答案 那些[Getter/Setter]成员表示有关错误对象的更多信息。您可以使用一个小的辅助函数轻松转储这些getter/setter的内容(非常
所以,我希望我的第一级catch是处理错误的那个。有没有办法将我的错误传播到第一次捕获?引用代码,不工作(还):Promise=require('./framework/libraries/bluebird.js');functionpromise(){varpromise=newPromise(function(resolve,reject){throw('Ohno!');});promise.catch(function(error){throw(error);});}try{promise();}//IWANTTHISCATCHTOCATCHTHEERRORTHROWNINTHE
我正在使用Promise,并且代码如下所示:functiongetStuff(){returnfetchStuff().then(stuff=>process(stuff)).catch(err=>{console.error(err);});}或者:asyncfunctiongetStuff(){try{conststuff=awaitfetchStuff();returnprocess(stuff);}catch(err){console.error(err);}}我这样做是为了避免遗漏错误,但一位用户告诉我我不应该这样做,并且不赞成这样做。return….catch(err=>c
我有几个可能的文件可以保存我的数据;它们可以用不同的方式压缩,所以要打开它们我需要使用file()、gzip.GzipFile()和其他也返回一个文件对象(支持带接口(interface))。我想尝试每一个,直到一个成功打开,所以我可以做类似的事情try:withgzip.GzipFile(fn+'.gz')asf:result=process(f)except(IOError,MaybeSomeGzipExceptions):try:withxCompressLib.xCompressFile(fn+'.x')asf:result=process(f)except(IOError,M
我连续有很多行可能会引发异常,但无论如何,它仍应继续下一行。如何在不单独trycatch每个可能引发异常的语句的情况下执行此操作?try:this_may_cause_an_exception()but_I_still_wanna_run_this()and_this()and_also_this()exceptException,e:logging.exception('Anerrormaybeoccuredinoneoffirstoccuringfunctionscausingtheothersnottobeexecuted.Locals:{locals}'.format(loca