Posted on 01/17/2018 | by liu
web前端|js教程
异常处理
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()); // 使用本地格式显示当前时间 }