首页 >

JS中的异常处理方法分享【javascript】

web前端|js教程JS中的异常处理方法分享【javascript】
异常处理
web前端-js教程
js容错语句,就是js出错也不提示错误(防止浏览器右下角有个黄色的三角符号,要不用户体验不好)
企业网站源码 ne,vscode终止后台命令,ubuntu 模糊搜索,看懂tomcat日志,sqlite存放文件数据,jquery 拖拽多选插件,各种前端框架有意义吗,爬虫能在公司内网运行吗,php .net 哪个好,怎么对付seo骗局,获取网站信息插件,asp操作网页,phpcms后台模板在哪lzw
 
window.onerror=function(){return true;}

下面是为了获取js异常信息,方便开发者找回问题

1,try...catch...


var txt=""
function message()
{
try
{
adddlert("Welcome guest!")
}
catch(err)
{
txt="本页中存在错误。\n"
txt+="点击“确定”继续查看本页,\n"
txt+="点击“取消”返回首页。\n"
if(!confirm(txt))
{
document.location.href="/index.html"
}
}
}

2 ,throw


var x=prompt("请输入 0 至 10 之间的数:","")
try
{
if(x>10)
throw "Err1"
else if(x<0)
throw "Err2"
else if(isNaN(x))
throw "Err3"
}
catch(er)
{
if(er=="Err1")
alert("错误!该值太大!")
if(er == "Err2")
alert("错误!该值太小!")
if(er == "Err3")
alert("错误!该值不是数字!")
}

3,onerror:


onerror=handleErr
var txt=""

function handleErr(msg,url,l)
{
txt="本页中存在错误。\n"
txt+="错误:" + msg + "\n"
txt+="URL: " + url + "\n"
txt+="行:" + l + "\n\n"
txt+="点击“确定”继续。\n"
alert(txt)
return true
}

function message()
{
adddlert("Welcome guest!")
}


js中的异常处理

在JavaScript可以使用try...catch来进行异常处理。例如:
try { foo.bar();} catch (e) { alert(e.name + ": " + e.message);}
目前我们可能得到的系统异常主要包含以下6种:

EvalError: raised when an error occurs executing code in eval()
RangeError: raised when a numeric variable or parameter is outside of its valid range
ReferenceError: raised when de-referencing an invalid reference
SyntaxError: raised when a syntax error occurs while parsing code in eval()
TypeError: raised when a variable or parameter is not a valid type
URIError: raised when encodeURI() or decodeURI() are passed invalid parameters
上面的六种异常对象都继承自Error对象。他们都支持以下两种构造方法:
new Error();new Error("异常信息");
手工抛出异常的方法如下:


try {
throw new Error("Whoops!");}
catch (e) {
alert(e.name + ": " + e.message);}

如要判断异常信息的类型,可在catch中进行判断:

方维6.0源码,vscode导入配置插件,惠普ubuntu卡,删除服务启动tomcat,sqlite3首次自动创建,爬虫舆情,php微信退款demo,浙江seo优化口碑推荐,wp网站成功案例,模板编辑器booklzw

try {
foo.bar();
} catch (e) {
if (e instanceof EvalError) {
alert(e.name + ":" + e.message);
} else if (e instanceof RangeError) {
alert(e.name + ": " + e.message); }
// etc
}

Error具有下面一些主要属性:

description: 错误描述 (仅IE可用).
fileName: 出错的文件名 (仅Mozilla可用).
lineNumber: 出错的行数 (仅Mozilla可用).
message: 错误信息 (在IE下同description)
name: 错误类型.
number: 错误代码 (仅IE可用).
stack: 像Java中的Stack Trace一样的错误堆栈信息 (仅Mozilla可用).
因此为了更好的了解错误信息我们可以将catch部分改为如下形式:

信息收集系统源码,vscode 发布,ubuntu搜索工具,tomcat 7.0.2,web调用sqlite,阿里云免备案服务器,显示价格日历插件,web前端基础框架,网络爬虫答辩ppt,php验证码显示不出来,seo学习总结,网站三级栏目,frontpage网页特效,美食中国风网页模板,页面导航条,开源源数据管理系统,电商小程序源码lzw

try {
foo.bar();
} catch(e) {
if (browserType != BROWSER_IE) {
alert("name: " + e.name + "message: " + e.message + "lineNumber: " + e.lineNumber + "fileName: " + e.fileName + "stack: " + e.stack);
} else {
alert("name: " + e.name + "errorNumber: " + (e.number & 0xFFFF) + "message: " + e.message "); } } "

JavaScript中的throw命令事实上可以抛出任何对象,并且我们可以在catch接受到此对象。例如:

try {
throw new Date(); // 抛出当前时间对象 } catch (e) { alert(e.toLocaleString()); // 使用本地格式显示当前时间
}

JS中的异常处理方法分享【javascript】
  • PHP 异常处理 Exception 类,异常处理exception
  • PHP 异常处理 Exception 类,异常处理exception | PHP 异常处理 Exception 类,异常处理exception ...

    JS中的异常处理方法分享【javascript】
  • PHP异常处理浅析【PHP】
  • PHP异常处理浅析【PHP】 | PHP异常处理浅析【PHP】 ...

    JS中的异常处理方法分享【javascript】
  • MySQL存储过程的异常处理方法【MySQL】
  • MySQL存储过程的异常处理方法【MySQL】 | MySQL存储过程的异常处理方法【MySQL】 ...