<script type="text/javascript">
alert(str);//因為沒有定義str,所以瀏覽器會出錯,下面的不能運行
alert("我是代碼塊一");//沒有運行到這里
var test = "我是代碼塊一變量";
</script>
<script type="text/javascript">
alert("我是代碼塊二"); //這里有運行到
alert(test); //彈出"我是代碼塊一變量"
</script>
- 上面的代碼中代碼塊一中運行報錯,但不影響代碼塊二的執行,這就是代碼塊間的獨立性,而代碼塊二中能調用到代碼一中的變量,則是塊間共享性。
>>> JS的執行步驟:
step 1. 讀入第一個代碼塊。
step 2. 做語法分析,有錯則報語法錯誤(比如括號不匹配等),并跳轉到step5。
step 3. 對var變量和function定義做“預編譯處理”(永遠不會報錯的,因為只解析正確的聲明)。
step 4. 執行代碼段,有錯則報錯(比如變量未定義)。
step 5. 如果還有下一個代碼段,則讀入下一個代碼段,重復step2。
step 6. 結束。