js try catch 的使用,容错处理

tag: js try catch 的使用,js容错处理

网友回答:

  try{
      //正常执行
  }catch(e/*你感觉会出错的 错误类型*/){
     // 可能出现的意外  eg:用户自己操作失误 或者 函数少条件 不影响下面的函数执行
     // 有时也会用在 比如 focus()  但可恶的ie有可能会第一次没有focus事件 再让他执行一次
     //  有时一些不是bug的bug  在ie上 他要求必须加上 catch  哪怕就一个空catch 以前在ie8上遇到过这个操蛋的js问题
  }
  throw ‘出错 抛出 效果等同 for循环中的 break 直接停止该函数的运行‘


网友回答:
异步用不了



网友回答:
try catch的使用,永远应该放在你的控制范围之内,而不应该防范未知的错误。也就是说你很清楚知道这里是有可能”出错“的,而且你很清楚知道什么前提下会出错,你就是要故意利用报错信息来区分错误,后续的程序会解决所有的出错,让程序继续执行。
如果让用户先发现你根本没预料到的错误,而不是你先发现错误,你是失职的。
大多数情况下,try catch适用于两种场合:
1、浏览器原罪的场合:也就是兼容性场合,因为浏览器兼容性不是程序员能改正的,所以只能try catch:由于不同浏览器的报错提示是不一样的,根据捕获的浏览器的报错提示判断用户的浏览器,然后做出对应的措施,这时候使用try catch是巧妙的办法,如果用if就比较笨拙,因为if通常只能反馈真或假,不能直接反馈浏览器的报错内容。
2、考虑如下代码。window.a.b是非法的,再跟2对比就没有意义,这样非法的条件,在try catch中仍可以继续运行下去。但在if中window.a.b已经报错,整个页面都会坏掉。如果希望用if写,那么必须先判断window.a是否是合法的,window.a是合法的前提下再判断window.a.b是不是合法的,如果也是合法的,再判断window.a.b是否不等于2,这样是不是很蠢?这时就体现出try catch的妙处了,程序不但知道window.a.b !== 2是假的,而且直接可以知道究竟哪一步就已经是假的。
再想象一下,有一个变量是json.a.b.c,其中的a/b/c都可能是存在的也可能是不存在的,全看具体情况,这时候你简单的写if (json.a.b.c === 2) {…}是不行的,因为json.a.b就可能已经是非法的,所以你如果用if,就要考虑a是不是非法的、a是合法前提下b是不是非法的,b是合法前提下c是不是非法的。但是json.a.b.c === 2在try中就可以直接写,也就是说,我不关心究竟a/b/c谁是非法的,我只关心json.a.b.c到底是不是等于2,不等于2或者任何一步出错,对我来讲没有区别,反正都是不等于2,我不关心哪步出错,而且程序不会坏掉。这是一种比较省心的写法。
另外注意,try catch不能做真假判断,只能做非法判断。也就是说:try {1 === 2},虽然1===2是假,但是是合法的,catch不会捕捉到错误,也不会告诉你1 === 2到底是真是假。所以,写在try里的应该是json.a.b.c而不是json.a.b.c === 2。究竟是不是等于2,是后面的事,是if干的事。简单说,try catch用于捕捉报错,当你不关心哪一步错误,只关心有没有错,就用try catch。

  try {
     window.a.b !== 2
  }
  catch(err){
       alert(err) // 可执行
       alert(123) // 可执行
  }
  if (window.a.b !== 2) {
    alert("error") // 不执行
  }
  alert(123); // 不执行


网友回答:
1、事情还有得挽回,换条路走

  try {
  执行某个逻辑
  } catch (e) {
  出问题鸟,换个逻辑执行
  }

2、体面的退出

  try {
  正常流程
  } catch (e) {
  弹个框告诉用户不好意思出了点问题
  如果是用户的错就告诉用户什么地方错了
  如果是程序的错,就告诉用户不好意思没法执行
  }


网友回答:
偶认为,异常处理和错误处理是两个不同的概念。例如NodeJS里大多数error都是用来处理异常的,因为异常是不可避免的,例如数据库挂了,网络错误,你虽然知道有可能,但是不知道何时发生,这些异常你需要捕捉或者传给上层。而错误处理,则是一些基本的判定,可以从代码级别避免其发生,可预知可推测,如果发生了,不是系统问题,而是你的程序有bug了。
对于NodeJS来说,两种错误都时刻需要注意,特别是系统错误,因为不可预知,需要大量代码来catch错误,传递错误,最后统一处理。
而对于前端,系统错误出现的场景相对来说低得多,主要是一些io场景,大部分前端可能不太关心。而普通的错误处理,则比较常见,因为前端耦合的特定系统比较多,和这些系统操作的时候,数据和dom啊什么的大多是可预知的,跟系统错误还是要区分开的,一些错误,需要你自己去吞并和处理,如果出现错误,显然是bug,而不是不可预知。
bulabula,记事本里相关的一片文章躺了很久了,至今写了不到一半,太监了。

?

时间: 2024-10-15 14:36:02

js try catch 的使用,容错处理的相关文章

JS try catch用法

try{ //正常执行 }catch(e/*你感觉会出错的 错误类型*/){ // 可能出现的意外 eg:用户自己操作失误 或者 函数少条件 不影响下面的函数执行 // 有时也会用在 比如 focus() 但可恶的ie有可能会第一次没有focus事件 再让他执行一次 // 有时一些不是bug的bug 在ie上 他要求必须加上 catch 哪怕就一个空catch }

js - try..catch详解

try... catch 1.try...catch和if语句 为什么不用if替换调try...catch? 大部分人都有这样想法 if=>只能判断用户操作 try...catch=>来自程序异常和用户操作(程序异常的话if貌似处理不了吧...) 2. try...catch不应该被滥用 try...catch应该用在程序容易出错的地方,而不是每一个地方都捕获它 3. try...catch实际操作 在真机调用这个api时,经常会操作不了.经debug发现调用量过大,腾讯地图通过接口返回过来报

异步编程:When.js快速上手

前些天我在团内做了一个关于AngularJS的分享.由于AngularJS大量使用Promise,所以我把基于Promise的异步编程也一并介绍了下.很多东西都是一带而过,这里再记录下. AngularJS内置的是Kris Kowal的Q框架,我介绍的是自己用得更多的cujoJS的when.js,两者都是Promises/A规范的实现.when.js很小,压缩后只有数kb,gzip后的大小几乎可以忽略.在Node和浏览器环境里都可以使用when.js,唯一需要注意的是:在浏览器使用时,要先加几行

使用javax.script包实现Java设置JS脚本中的变量

下面例子中,我们通过javax.script包ScriptEngine.put()方法设置JS脚本中的变量,JS把所有在线用户输出. package ajava.code.javase; import javax.script.ScriptEngineManager; import javax.script.ScriptEngine; import javax.script.ScriptException; import java.util.Date; public class AjavaAcc

JSON格式化着色小工具

在我们系统开发过程中越来越多的使用JSON作为数据交换的载体.JSON的特点是层次结构简洁清晰,易于人阅读和编写.同时也易于机器解析和生成.对于机器解析和生成这点本人表示认可,然而对于易于人阅读和编写可以通过下面一段JSON字符串来验证下: {"strValue":"here is str value","nullValue":null,"intvalue":999,"doublevalue":999,&q

unity 打包AssetBundle

unity提供了assetbunlde机制,下面介绍一种方法将指定目录下的所有文件打包成AssetBundle 先说明步骤,再上代码. 步骤一.选择要打包成assetbundle的目录,本案例使用assetbundle_raw 步骤二.把要打包的资源或者目录都放到assetbundle_raw目录,资源可以是 prefab,png,fbx,font,audio,txt等. 步骤三.给assetbundle_raw目录下所有的资源文件设置assetbundle名称,如果是目录,会递归. 名称格式:

使用HtmlParser抓去网页内容

package parser; import org.htmlparser.Parser; import org.htmlparser.beans.StringBean; importorg.htmlparser.filters.NodeClassFilter; importorg.htmlparser.parserapplications.StringExtractor; import org.htmlparser.tags.BodyTag; import org.htmlparser.uti

erlang与设计模式(一)——概述、单例、原型

Russell-X-Shanso 大家好,我是狼夜行(嫌不好记叫我哈士奇也成).仅以此系列随笔跟大家来讨论一下erlang和设计模式. 本文背景: (1)设计模式在面向对象语言编程中广泛受到关注: (2)对于非面向对象语言而言,各领域的朋友也有总结一些设计模式,整体受众及受关注度不大: (3)国内erlang圈不大,玩票的游击队朋友较多,新手引导少: 本文目标: (1)按面向对象中设计模式的套路生搬硬套过来,借用erlang的形式向erlang为主要语言的朋友们进行介绍,希望对两者更熟悉的朋友能

GridView按钮事件

1.html代码 <asp:TemplateField HeaderText="操作"> <ItemTemplate> <div style="width: 129px"> <asp:Button ID="btnPass" runat="server" Text="通过" OnCommand="pass" CommandArgument=&quo