错误处理与调试:

1、try-catch

try{

window.someNoneXistentFunction();

}catch(error){

alert(error.message)

}

2、finally子句一经使用,就会执行

try{

return 2;

}catch(error){

return 1;

}finally{

return 0;

}

3、throw操作符:随时抛出自定义错误,遇到throw操作符时,就会立即停止执行,仅当有try-catch语句捕获到被抛出的值时,代码才会继续执行

throw new Error(“zzzzz”);

4、关于原型继承

function CustomError(message){

this.name="CustomError";

this.message=message;

}

CustomError.prototype=new Error();

throw new CustomError("My message");

5、error事件

EventUtil.addHandler(image,"error",function(event){

alert("image not loaded!");

});

image.src="zhang.gif";//指定不存在的文件

6、基本类型的值使用typeof检测,对象的值使用instanceof检测

7、错误日志:

function logError(sev,msg){

var img=new Image();

img.src="log.php?sev="+encodeURIComponent(sev)+"&msg="+

encodeURIComponent(msg);

}

for(var i=0,len=mods.length;i<len;i++){

try{

mods[i].init();

}catch(ex){

logError("nonfatal","Module init failed:" + ex.message);-- nonfatal表示错误的严重程度

}

}

Json:

1、json的语法可以表示以下三种类型的值:

简单值:字符串,数值,布尔值,null,不支持undefined

对象:

数组:

不支持变量,函数以及对象实例

json字符串必须使用双引号

2、对象:

{

"name":"zhang",

"age":29,

"school":{

"name":"zzz",

"location":"zzzzzz"

}

} ----没有分号

3、Json对象有两个方法:

stringify():把js对象序列化为JSON字符串

parse():将JSON字符串解析为js值

var book={

title:"aaaa",

authors:["aaaa"],

edition:3,

year:2011

};

var jsonText=JSON.stringify(book);

// jsonText是不包含任何空格字符或缩进

var bookCopy=JSON.parse(jsonText);

4、stringify()还可以接受另外一个参数:

第一个;

var jsonText=JSON.stringify(book,[“title”,”edition”]);

第二个:

函数,函数接收两个参数,属性名以及属性值

5、字符串缩进:--- stringify()的另一个参数

var jsonText=JSON.stringify(book,null,4);

最大缩进空格为10

不仅仅可以传空格:

var jsonText=JSON.stringify(book,null,“--”);

5、toJSON()方法:

var book={

title:"aaaa",

authors:["aaaa"],

edition:3,

year:2011

toJSON:function(){

return this.title;

}

};

var jsonText=JSON.stringify(book);

6、解析选项:

JSON.parse()方法也可以接收另一个参数,是一个函数(还原函数):

如果还原函数返回的是一个undefined,则表示要从结果中删除相应的键,如果返回其它值,则将该值插入到结果中

var book={

title:"aaaa",

authors:["aaaa"],

edition:3,

year:2011

releaseDate:new Date(2011,11,1)

};

var jsonText=JSON.stringify(book);

var bookCopy=JSON.parse(jsonText,function(key,value){

if(key=="releaseDate"){

return new Date(value);

}else{

return value;

}

});

alert(bookCopy.releaseDate.getFullYear());

js-错误处理与调试,JSON的更多相关文章

  1. js错误: Unexpected number in JSON at position 2792 value里面有双引号怎么解决

    源头  出现这个报错提示,大家从错误就可以看的出来,这就是json的错误,一般来说都是json格式出现了错误,本人遇到比较多的情况就是json字符串里面出现了一些会影响json格式的符号,这次出现这个 ...

  2. JS 错误处理与调试

    在程序开发中难免会遇到一些错误,在成千上万的代码中去寻找错误非常明显相当于大海捞针.为此,每种计算机编程语言都要它独特的一套错误处理与调试机制.当然,JavaScript也不例外. 错误发生: 运行代 ...

  3. js错误处理和调试

    1.重点关注函数和可能导致函数执行失败的因素. 2.抛出错误和使用try-catch的时机:一般来说在应用程序架构较低的层次中经常会抛出错误.这个层次并不会影响当前执行的代码. 错误也得不到真正的处理 ...

  4. 在Visual Studio上开发Node.js程序(2)——远程调试及发布到Azure

    [题外话] 上次介绍了VS上开发Node.js的插件Node.js Tools for Visual Studio(NTVS),其提供了非常方便的开发和调试功能,当然很多情况下由于平台限制等原因需要在 ...

  5. 第一百二十三节,JavaScript错误处理与调试

    JavaScript错误处理与调试 学习要点: 1.浏览器错误报告 2.错误处理 3.错误事件 4.错误处理策略 5.调试技术 6.调试工具 JavaScript在错误处理调试上一直是它的软肋,如果脚 ...

  6. 前端监控系统(二)JS错误日志收集篇

    前端监控系统 目前已经上线,欢迎使用! 服务器搭建好了,可以着手开发了. 其实前端需要分析的数据有很多,包括,PVUV, 接口请求统计,耗时统计,JS错误统计,用户使用设备统计,用户地域分布,页面用户 ...

  7. 搭建前端监控系统(二)JS错误监控篇

    ===================================================================== 前端性能监控系统: DEMO地址    GIT代码仓库地址 ...

  8. Webfunny知识分享:JS错误监控

    现在的前端开发已不再是刀耕火种的年代了,各种框架.编译工具层出不穷,前端监控系统也不甘其后,遍地开花. 前端正承受着越来越重的职责,前端的业务也变得越来越复杂,此时此刻我们就更需要一套完善的监控系统来 ...

  9. Node.js在Chrome进行调试

    在开发node.js环境时候,调试是一件很疼苦的事情,不过随着时代不断发展,先如今已经有很多种node环境代码调试方式,今天我就笔记一下我使用的方式 node-inspector: node-insp ...

  10. js中js数组、对象与json之间的转换

    在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键.例如:JSON字符串:var str1 = '{ &quo ...

随机推荐

  1. 【leetcode】Reverse Linked List II (middle)

    Reverse a linked list from position m to n. Do it in-place and in one-pass. For example:Given 1-> ...

  2. 【编程题目】求1+2+…+n, 要求不能使用乘除法、for、while、if、else、switch、case和条件语句

    看到这个问题,第一个反应是真变态啊. 然后,直觉是不能用循环就只能用递归了.可递归怎么跳出来却遇到了麻烦, 我连goto语句都考虑了也没弄好. 后来想到一个非常NC的方法:查找表. 如果n限定一个比较 ...

  3. 关于Javascript splice方法的一个坑。

    w3c相关文档:http://www.w3school.com.cn/jsref/jsref_splice.asp bug:购物车计算价格的时候.加商品没问题,减商品的时候价格总是计算错误. 经排查发 ...

  4. Ubuntu(Linux)使用Eclipse搭建C/C++编译环境

    转自:http://www.cppblog.com/kangnixi/archive/2010/02/10/107636.html 首先是安装Eclipse,方法有两种:       第一种是通过Ub ...

  5. iOS 百度地图坐标标注

    注:由于iOS9改用更安全的https,为了能够在iOS9中正常使用地图SDK,请在"Info.plist"中进行如下配置,否则影响SDK的使用. <key>NSApp ...

  6. Swift - 键盘弹出样式

    Swift提供了11种键盘类型: 在开发中,我们可以根据不同的需求,选择不同的键盘样式,例如,当我们只需要输入手机号码时,可以选择纯数字类型的键盘(.NumbersAndPunctuation),当我 ...

  7. CentOS7下Firewall防火墙配置用法详解

    官方文档地址: https://access.redhat.com/documentation/en-US/Red_Hat_Enterprise_Linux/7/html/Security_Guide ...

  8. 三、jQuery--jQuery基础--jQuery基础课程--第11章 jQuery 工具类函数

    1.获取浏览器的名称与版本信息 在jQuery中,通过$.browser对象可以获取浏览器的名称和版本信息,如$.browser.chrome为true,表示当前为Chrome浏览器,$.browse ...

  9. python字符串中插入变量

  10. devices-list

    转自:https://www.kernel.org/pub/linux/docs/lanana/device-list/devices-2.6.txt LINUX ALLOCATED DEVICES ...