西西軟件園多重安全檢測下載網(wǎng)站、值得信賴的軟件下載站!
軟件
軟件
文章
搜索

首頁編程開發(fā)javascript|JQuery → Javascript未必全了解的標(biāo)識符順序

Javascript未必全了解的標(biāo)識符順序

相關(guān)軟件相關(guān)文章發(fā)表評論 來源:西西整理時間:2010/11/17 11:16:01字體大。A-A+

作者:佚名點擊:44次評論:0次標(biāo)簽: Javascript

  • 類型:電子教程大。3.3M語言:中文 評分:3.6
  • 標(biāo)簽:
立即下載

 

一、局部變量先使用后聲明,不影響外部同名變量
Js代碼
1.var x = 1; // --> 外部變量x   
2.function fn(){   
3.    alert(x);  // --> undefined 局部變量x先使用   
4.    var x = 2; // 后聲明且賦值   
5.}   
6.fn();   
7.alert(x); // --> 1  
var x = 1; // --> 外部變量x
function fn(){
    alert(x);  // --> undefined 局部變量x先使用
    var x = 2; // 后聲明且賦值
}
fn();
alert(x); // --> 1

第一點,函數(shù)fn內(nèi)第一句輸出x,x是在第二句才定義的。這在js中是允許的,這里的允許是指不會出現(xiàn)語法錯誤程序可以運(yùn)行。
但在其它語言如C,Java中卻是不允許的。變量必選先聲明后使用,如:

Java代碼
1.public class Test {   
2.    public static void main(String[] args) {   
3.        System.out.println(x); // 先使用   
4.        int x = 10; // 后聲明   
5.    }   
6.}  
public class Test {
    public static void main(String[] args) {
        System.out.println(x); // 先使用
        int x = 10; // 后聲明
    }
}

Java中編譯器會提示錯誤,程序無法運(yùn)行。

第二點,函數(shù)fn內(nèi)的局部變量x不會影響到外部的變量x。即fn內(nèi)alert輸出不是1,而是undefined。

順便提下,這段代碼經(jīng)常出現(xiàn)在前端面試題中。


  二、形參優(yōu)先級高于函數(shù)名
Js代碼
1.function fn(fn){   
2.    alert(fn);   
3.}   
4.fn('hello'); // --> "hello"  
function fn(fn){
    alert(fn);
}
fn('hello'); // --> "hello"

可以看到函數(shù)名和形參同名都是fn,輸出的是字符串"hello",卻不是函數(shù)fn的函數(shù)體(fn.toString())。



  三、形參優(yōu)先級高于arguments
Js代碼
1.function fn(arguments){   
2.    alert(arguments);   
3.}   
4.fn('hello'); // --> "hello"  
function fn(arguments){
    alert(arguments);
}
fn('hello'); // --> "hello"

arguments對象可以直接在函數(shù)內(nèi)使用,是語言本身提供的標(biāo)識符。
這里剛好將形參聲明成與其同名。輸出可以看到是"hello"而非"[object Object]",即形參arguments覆蓋了語言本身提供的真正的arguments。



  四、形參優(yōu)先級高于只聲明卻未賦值的局部變量
Js代碼
1.function fn(a){   
2.    var a;   
3.    alert(a);   
4.}   
5.fn('hello'); // --> "hello"  
function fn(a){
    var a;
    alert(a);
}
fn('hello'); // --> "hello"

函數(shù)fn形參為a,函數(shù)內(nèi)第一句僅聲明局部變量a,卻并未賦值。從輸出結(jié)果是"hello"而非undefined可以看出形參a優(yōu)先級高于僅聲明卻未賦值的局部變量a。


  五、聲明且賦值的局部變量優(yōu)先級高于形參
Js代碼
1.function fn(a){   
2.    var a = 1;   
3.    alert(a);   
4.}   
5.fn('hello'); // --> "1"  
function fn(a){
    var a = 1;
    alert(a);
}
fn('hello'); // --> "1"

函數(shù)fn形參為a,函數(shù)內(nèi)第一句僅聲明局部變量a,賦值為1。從輸出結(jié)果是"1"而非"hello"可以看出聲明且賦值的局部變量a優(yōu)先級高于形參a。





  六、了解了以上幾點,再看一個有趣的代碼
Js代碼
1.function fn(a){   
2.    var a = a;   
3.    alert(a);   
4.}   
5.fn('hello');  
function fn(a){
    var a = a;
    alert(a);
}
fn('hello');

暫不運(yùn)行,猜測下結(jié)果。如果按照第五點:聲明且賦值的局部變量優(yōu)先級高于形參。那么a將是undefined。但實際上a是"hello",即右a是形參a,左a才是局部變量a。


  這里的兩個a互不干擾,誰也沒覆蓋誰。這與剛剛說的賦值的局部變量優(yōu)先級高于形參又矛盾了。但引擎這樣做的確是我們想要的,因為并不希望var a = a后a是undefined。


圖片:

 

    相關(guān)評論

    閱讀本文后您有什么感想? 已有人給出評價!

    • 8 喜歡喜歡
    • 3 頂
    • 1 難過難過
    • 5 囧
    • 3 圍觀圍觀
    • 2 無聊無聊

    熱門評論

    最新評論

    發(fā)表評論 查看所有評論(0)

    昵稱:
    表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
    字?jǐn)?shù): 0/500 (您的評論需要經(jīng)過審核才能顯示)