JavaScript严格模式禁用With语句的原因

 更新时间:2014年10月20日 15:58:50   投稿:whsnow  
看了很多遍JavaScript严格模式,其中有说“禁用With语句”今天禁不住想知道为何“严格模式”就容不下with语句呢,如果你也表示疑惑可以看看哦

看了很多遍JavaScript严格模式,其中有说“禁用With语句”,以前看到这都是骑马观花,一带而过,因为平时就很少用到这个语句,禁不禁用对自己关系都不是很大。今天禁不住想知道为何“严格模式”就容不下with语句呢?

EcmaScript规范上说“with 语句用于设置代码在特定对象中的作用域”,可以看出,With语句改变了作用域链。

function Person(name,age,sex){
this.name = name;
this.age = age;
this.sex = sex;
}
(function(){
var title = '申请人:';
var zhangsan = new Person('张三',20,'男');
var str = '';
with(zhangsan){
str = title+name+',年龄'+age+'岁,'+sex+'性'+',职位'+job;
}
console.log(str);
})();

上面的代码会报Uncaught ReferenceError: job is not defined 。

如果将上面的with语句块改为

str = title+zhangsan.name+',年龄'+zhangsan.age+'岁,'+zhangsan.sex+'性'+',职位'+zhangsan.job;

则不报错,输出str 为:申请人:张三,年龄20岁,男性,职位undefined

对于with语句块中的变量,在执行时,都要在zhangsan中检查是否它的属性。

我们知道运行脚本时,需要两个过程,首先是编译,然后再执行。
很显然在编译的时候,不能确定zhangsan的这变量表示的对象有哪些属性。只能在执行时才能确定zhangsan是Person的一个实例。所以就不能在编译时确实with语句块中的变量是zhangsan的属性还是上一层变量作用域链中的变量。

这与严格模式有编译时就检查变量是否定义冲突,所以严格模式不会允许异已存在,因此严格模式禁用With语句,也就不难理解了。

相关文章

  • 微信小程序多音频播放进度条问题

    微信小程序多音频播放进度条问题

    小程序的音频组件居然没有进度控制的功能,需要我们自己实现,下面脚本之家小编给大家带来了微信小程序多音频播放进度条问题,感兴趣的朋友一起看看吧
    2018-08-08
  • uni-app常用的几种页面跳转方式总结

    uni-app常用的几种页面跳转方式总结

    uni-app的页面跳转和小程序和vue很相似,只是方法和标签有所不同,这篇文章主要给大家介绍了关于uni-app常用的几种页面跳转方式,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • JavaScript小技巧 2.5 则

    JavaScript小技巧 2.5 则

    在上一篇文章中的(伪)Lambda模块中使用了几个小技巧,现在我就把这几个小技巧介绍一下
    2010-09-09
  • 基于zepto.js实现手机相册功能

    基于zepto.js实现手机相册功能

    这篇文章主要为大家详细介绍了基于zepto.js实现手机相册功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • JavaScript中innerHTML,innerText,outerHTML的用法及区别

    JavaScript中innerHTML,innerText,outerHTML的用法及区别

    在javascript中如果我们要获取对象内容,js为我们提供了三种方法outerhtml、innerhtml和innertext,但他们之间具体怎么使用与具体的区别在哪里,可能很多人不知道吧,接下来跟着小编一起来学习innerHTML,innerText,outerHTML的用法及区别吧。
    2015-09-09
  • js尾调用优化的实现

    js尾调用优化的实现

    这篇文章主要介绍了js尾调用优化的实现,尾调用(Tail Call)是函数式编程的一个重要概念,本文介绍它的含义和用法。感兴趣的可以了解一下
    2019-05-05
  • JS实现HTML表格排序功能

    JS实现HTML表格排序功能

    这篇文章主要为大家详细介绍了JS实现HTML表格排序功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • 键盘KeyCode值列表汇总

    键盘KeyCode值列表汇总

    这篇文章主要是对键盘KeyCode值进行了详细的汇总,需要的朋友可以过来参考下,希望对大家有所帮助
    2013-11-11
  • JavaScript、C# URL编码、解码总结

    JavaScript、C# URL编码、解码总结

    这篇文章主要介绍了JavaScript、C# URL编码总结,注意包括了encodeURI、decodeURI、encodeURIComponent、decodeURIComponent等使用需要的朋友可以参考下
    2017-01-01
  • 论Bootstrap3和Foundation5网格系统的异同

    论Bootstrap3和Foundation5网格系统的异同

    这篇文章主要介绍了Bootstrap3和Foundation5网格系统,网格的基本构造,如何构建的,描述它们的主要部件,以及它们对不同屏幕的大小表现出的差异,感兴趣的小伙伴们可以参考一下
    2016-05-05

最新评论