草庐IT

try-catch-else

全部标签

javascript - 公理。即使 api 返回 404 错误,如何在 try catch finally 中获得错误响应

例如(async()=>{letapiRes=null;try{apiRes=awaitaxios.get('https://silex.edgeprop.my/api/v1/a');}catch(err){console.error(err);}finally{console.log(apiRes);}})();在finally中,apiRes将返回null。即使api收到404响应,响应中仍然有我想使用的有用信息。当axios抛出错误时,如何在finally中使用错误响应。https://jsfiddle.net/jacobgoh101/fdvnsg6u/1/

JavaScript:使用严格模式在 try/catch 中定义一个常量

今天我遇到了一个奇怪的JS错误,在try/catchblock中使用const,我想更好地了解导致它的原因。让我们看一个代码示例,它的值(value)超过一千字:try{constFOO='bar';console.log('inside:',FOO);}catch(e){}console.log('outside:',FOO);这将记录:inside:baroutside:bar不过,如果我们切换到“严格模式”:'usestrict';try{constFOO='bar';console.log('inside:',FOO);}catch(e){}console.log('outsi

javascript - doT.js:在 dot.js 中链接 if-else

我正在尝试doT.js模板引擎。如果在dot.js中如何嵌套if-else就像if().....elseif.....elseif.....else..... 最佳答案 您可以使用以下语法:{{?it.name}}Oh,Iloveyourname,{{=it.name}}!{{??it.age===0}}Guessnobodynamedyouyet!{{??it.age>20}}You'reold!{{??}}Youare{{=it.age}}andstilldon'thaveaname?{{?}}以上编译为:functionano

javascript - Promises 和通用的 .catch() 语句

我正在为我的系统编写一个API,它向服务器发送一个XHR并返回一个应该由调用者处理的promise-到目前为止一切顺利。对于每个API调用,我必须使用.then和.catch调用,但通常(大约75%的时间)是.catch引用了使用console.error简单打印的相同功能。我的问题是-有没有办法为我创建的每个promise附加一个默认的catch语句?(比如说打印到控制台),以及我想要的每个promise进一步处理拒绝,我会添加另一个.catch调用(甚至覆盖它)?每个调用都有自己的.catch的简化示例:http://jsbin.com/waqufapide/edit?js,con

javascript - 有没有办法将 await/async try/catch block 包装到每个函数?

所以我正在使用express.js并考虑将async/await与节点7一起使用。有没有一种方法我仍然可以捕获错误但摆脱try/catchblock?也许是函数包装器?我不确定这将如何实际执行函数的代码并调用next(err)。exports.index=asyncfunction(req,res,next){try{letuser=awaitUser.findOne().exec();res.status(200).json(user);}catch(err){next(err);}}像这样的……?functionexample(){//Implementstry/catchbloc

javascript - catch 之后执行

我有以下fiddle:http://jsfiddle.net/thelgevold/3uv9nnjm/6/angular.module('hello',[]).controller('helloController',function($q){console.clear();functionsomeService(){vardeferred=$q.defer();deferred.reject({e:'error'});returndeferred.promise;}functioncallService(){returnsomeService().then(function(obj)

javascript - 引用错误 : You are trying to `import` a file after the Jest environment has been torn down

我有一个组件使用来自ReactNative的Animated组件。我开始编写一个测试用例来模拟组件的onPress,它调用一个函数,其中包含Animated.timing和setState。运行jest工作正常,但测试永远不会停止运行,而且我之前编写的一个不相关的测试用例现在似乎从未通过(之前通过)。运行jest--watch,我得到这个错误:ReferenceError:Youaretryingto`import`afileaftertheJestenvironmenthasbeentorndown.atFunction.bezier(node_modules/react-nativ

Javascript 条件正则表达式 if-then-else

我试图将条目限制为特定格式。如果条目有5500或5100,例如01\01-5500-000-00那么我想要这个:^[0-9]{2,}\\[0-9]{2}\-[0-9]{4}\-[0-9]{3}\-$但是如果条目有5500或5100以外的任何东西,我想要这个:^[0-9]{2,}\\[0-9]{2}\-[0-9]{4}\-[0-9]{3}\-[0-9]{2}$如何使用ifthenelse想法来实现这一点? 最佳答案 JavaScript正则表达式引擎不支持条件正则表达式语法,但它可以通过包含2个替代项的非捕获组解决:具有积极的前瞻性和

javascript - 如何缩短 jquery 语法 if-else 语句?

我经常使用这些:$text=$menu.jqmData('menu-text')?$menu.jqmData('menu-text'):self.options.menuTxt;它已经是“速记”语法,但我想知道是否有可能进一步减少上面的行。肯定有比检查$menu.jqmData('menu-text')然后重新编写整个内容更好的方法。不是吗?感谢您的帮助! 最佳答案 更短的方法是使用双管道。如果第一个值是falsy,它基本上使用第二个值。$text=$menu.jqmData('menu-text')||self.options.m

javascript - react-transform-catch-errors 看起来不像 React 组件

我正在做一个React项目,我们正在使用React入门套件。我是这个项目的新手,当我从github克隆项目并使用npmstart启动项目时,它会启动服务器,但在网络检查器中我收到以下错误。UncaughtError:react-transform-catch-errors的imports[1]看起来不像React组件。已经在项目中工作的人不会收到此错误。但是,当我向一位friend要求获得一个新的克隆并做我做的同样的事情时,他也得到了同样的错误。我不知道需要发布哪些详细信息,所以如果有人需要更多详细信息,请询问。 最佳答案 最后我找