您好,登錄后才能下訂單哦!
<p id="scope3" style="color:red"></p>
var pscope3 = document.getElementById('scope3'); function scope3() { for(var i=0; i<10; i++){ } echo(pscope3, i); } scope3();
1、函數在java、C#等語言中,變量i只會在for循環語句中有定義,循環結束,i也就被銷毀了。但在JavaScript中,變量i是定義在scope3()活動對象中的,因此在它定義開始,就可以在函數內部訪問它。
2、打印出的i為“10”。
3、函數scope3等效于下面的代碼:
function scope3() { var i; for(i=0; i<10; i++){ } echo(pscope3, i); }
function anonymous() { var position = 'in anonymous'; (function(){ for(var i=0; i<10; i++){ } echo(pscope3, position);//打印顯示"in anonymous" })(); //pscope3.innerHTML += i;//報錯 } anonymous();
1、匿名函數可以用來模仿塊級作用域,避免上面的那個問題。
2、在for循環外部插入了一個私有作用域。在匿名函數中定義的任何變量,新航道托福都會在執行結束時被銷毀。
3、上面的那句注釋掉的話,取消注釋的話,就會顯示錯誤信息:“ReferenceError: i is not defined”。
4、作用域的關系大致如下:
5、position是定義在anonymous函數中的,但可以在匿名函數中打印出來,因為anonymous的作用域包住了匿名函數,在匿名函數中找不到position定義,就往外找。
function capture() { var ex = 'in capture'; try{ i; }catch(ex){ var position= 'in catch'; echo(pscope3, ex); //ReferenceError: i is not defined var ex = 'is catching'; echo(pscope3, position);//in catch echo(pscope3, ex);//is catching } echo(pscope3, position);//in catch echo(pscope3, ex); //in capture 不是catch中賦的值 echo(pscope3, window.ex); //undefined } capture();
1、catch的一個參數ex與capture函數下的局部變量ex同名。
2、catch中先打印ex,是錯誤信息,然后賦值為“is catching”,打印出來,但很奇怪,catch外面打印的ex是“in capture”,并不是里面覆蓋的值。
3、position在catch中定義,但是可以在catch的外面打印出來。
4、window.ex輸出的是undefined,也就是說ex不是全局的,因此可以推出catch后面的大括號是普通語句塊的性質。
5、ex的性質可以視為唯一一個把catch語句塊當做塊作用域的變量,是catch語句塊的局部變量。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。