JavaScript(十九) try,catch,es5标准模式

1. try,catch

容错,抓到错误信息,并且把抓到的错误信息给你

try的作用:当你不敢肯定这堆代码里有没有错误,你就把他放进try里面,比如

 第二行b没加双引号会报错,正常情况下后面的代码都不会执行,放在try里面以后,try里面的报错行后面的代码不会执行,但是外面的不受影响

 catch作用:当try里面有错误信息时,在catch里会打印错误信息

控制台输出:

 

如果try里面的代码没有错误,就不会执行catch里面的代码,catch的格式就是catch(e)

3.一个变量未经声明就使用,或者一个函数未经声明就调用

6.地址错误

4.写了个中文的冒号,低级错误

 2. es5严格模式

叫做

那么es3.0和es5.0产生冲突的部分就使用es5.0,否则使用es3.0

 2.1 启用es5.0,必须尊重严格模式

最顶端要写字符串形式的,这样才启用了es5.0模式

注意:es5.0里面不允许使用arguments.callee,这是和es3.0冲突

2.2 两种用法

“use strict”如果写在开头最顶上,表示es5.0应用到全局,也可以写在局部函数里面的最顶端,只有该函数用es5.0严格模式,其他不受影响

2.3  es5严格模式不允许有with(更改原型链浪费效率)

with:with里面的代码会按照正常的顺序执行,但是在with后面的括号里填上一个对象的话,它就把这个obj当成with所要执行的代码体的作用域链的最顶端,也就说它会改变作用域链

 2.4 局部this必须被赋值,赋什么就是什么

原来正常预编译过程this指向window。下面代码在es5下指向的是undefined,预编译的时候是空,

想让这个this有值的话,要不就加new(下二图),控制台结果就变成test{}生成对象了,类型归test所有

或者最下面变成下面这样:结果就是object{},也是给this赋值

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值