本文主要是介绍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的内部访问到错误对象。
这篇关于javascript 延长作用域链 与没有块级作用域的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!