javascript 延长作用域链 与没有块级作用域

转自javascript高级程序设计(第三版):

javascript的执行环境的类型共有两种:全局和局部(函数)。不过可以通过别的方法来延长作用域链。

1)try-catch语句的catch块

2)with语句


对于with语句来说,会将指定的对象添加到作用域的前面。也就是说,如果在局部环境中,使用with语句,对象会添加到局部环境中;如果在全局环境中,使用with语句,对象会添加到全局环境中。

with 语句是运行缓慢的代码块,尤其是在已设置了属性值时。大多数情况下,如果可能,最好避免使用它。

with使用的情况:

转自:http://www.cnblogs.com/lidabo/archive/2011/12/29/2306126.html JavaScript中With 语句使用方法实例

有了 With 语句,在存取对象属性和方法时就不用重复指定参考对象,在 With 语句块中,凡是 JavaScript 不识别的属性和方法都和该语句块指定的对象有关。With 语句的语法格式如下所示:
      With Object {
      Statements
      }
      对象指明了当语句组中对象缺省时的参考对象,这里我们用较为熟悉的 Document 对象对 With 语句举例。例如 当使用与 Document 对象有关的 write( )或 writeln( )方法时,往往使用如下形式:
      document.writeln(”Hello!“)
      如果需要显示大量数据时,就会多次使用同样的 document.writeln()语句,这时就可以像下面的程序那样,把所有以 Document 对象为参考对象的语句放到With 语句块中,从而达到减少语句量的目的。下面是一个With 语句使用的例子:
     

<html>
<head>
<title>JavaScript Unleashed</title>
</head>
<body>
<script type="text/javascript">
function test(){
with(document){
     write("您好 !");
     write("<br>这个文档的标题是 : \"" + title + "\".");
     write("<br>这个文档的 URL 是: " + URL);
     write("<br>现在您不用每次都写出 document 对象的前缀了 !");
    }
}  
</script>
<button οnclick="test()">test</button>
</body>
</html>

 


这样,您在使用 document 的方法和属性时就可以去掉 Document 前缀。
请注意程序中的 title 和 URL 均是 Document 对 象的属性,一般情况下应写作document.title 和document.URL 使用 With 语句,您只需指定一次参考对象,这同把每一行都用document.writeln()打印下来的结果一样,

对于catch语句来说,会创建一个新的变量对象,其中包含的是被抛出的错误对象的声明。在IE8及之前的javascript实现中,存在一个与标准不一样的地方,即在catch语句中捕获的错误对象会被添加到执行环境的变量对象,而不是catch语句的变量对象中。换句话说,即使是在catch块的外部也可以访问到错误对象。IE9中修复了这个问题。也就是说,在IE9以后的版本中,只能在catch的内部访问到错误对象。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值