新聞中心
一,局部變量先使用后聲明,不影響外部同名變量

創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的天等網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
- var x = 1; // --> 外部變量x
- function fn(){
- alert(x); // --> undefined 局部變量x先使用
- var x = 2; // 后聲明且賦值
- }
- fn();
- alert(x); // --> 1
第一點(diǎn),函數(shù)fn內(nèi)第一句輸出x,x是在第二句才定義的。這在JS中是允許的,這里的允許是指不會(huì)出現(xiàn)語法錯(cuò)誤程序可以運(yùn)行。
但在其它語言如C,Java中卻是不允許的。變量必須先聲明后使用,如
- public class Test {
- public static void main(String[] args) {
- System.out.println(x); // 先使用
- int x = 10; // 后聲明
- }
- }
Java中編譯器會(huì)提示錯(cuò)誤,程序無法運(yùn)行。
第二點(diǎn),函數(shù)fn內(nèi)的局部變量x不會(huì)影響到外部的變量x。即fn內(nèi)alert輸出不是1,而是undefined。
二,形參優(yōu)先級(jí)高于函數(shù)名
- function fn(fn){
- alert(fn);
- }
- fn('hello'); // --> "hello"
可以看到函數(shù)名和形參同名都是fn,輸出的是字符串"hello",卻不是函數(shù)fn的函數(shù)體(fn.toString())。
三,形參優(yōu)先級(jí)高于arguments
- function fn(arguments){
- alert(arguments);
- }
- fn('hello'); // --> "hello"
arguments對(duì)象可以直接在函數(shù)內(nèi)使用,是語言本身提供的一個(gè) 特殊標(biāo)識(shí)符 。
這里剛好將形參聲明成與其同名。輸出可以看到是"hello"而非"[object Object]",即形參arguments覆蓋了語言本身提供的真正的arguments。
四,形參優(yōu)先級(jí)高于只聲明卻未賦值的局部變量
- function fn(a){
- var a;
- alert(a);
- }
- fn('hello'); // --> "hello"
函數(shù)fn形參為a,函數(shù)內(nèi)第一句僅聲明局部變量a,卻并未賦值。從輸出結(jié)果是"hello"而非undefined可以看出形參a優(yōu)先級(jí)高于僅聲明卻未賦值的局部變量a。
五,聲明且賦值的局部變量?jī)?yōu)先級(jí)高于形參
- 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)先級(jí)高于形參a。
六,形參賦值給同名局部變量時(shí)
- function fn(a){
- var aa = a;
- alert(a);
- }
- fn('hello');
暫不運(yùn)行,猜測(cè)下結(jié)果。如果按照第五點(diǎn):聲明且賦值的局部變量?jī)?yōu)先級(jí)高于形參。那么a將是undefined。但實(shí)際上a是"hello",即右a是形參a,左a才是局部變量a。
這里的兩個(gè)a互不干擾,誰也沒覆蓋誰。這與剛剛說的賦值的局部變量?jī)?yōu)先級(jí)高于形參又矛盾了。但引擎這樣做的確是我們想要的,因?yàn)椴⒉幌M鹶ar a = a后a是undefined。
原文鏈接:http://www.cnblogs.com/snandy/archive/2011/03/11/1980399.html
【編輯推薦】
- 淺析JavaScript繼承方式
- 淺析JavaScript的寫類方式
- 如何編寫高質(zhì)量的Javascript代碼
- 深入理解JavaScript的閉包特性
- JavaScript中大括號(hào)“{}”的多義性
網(wǎng)頁名稱:JavaScript中同名標(biāo)識(shí)符優(yōu)先級(jí)詳解
網(wǎng)站鏈接:http://www.5511xx.com/article/dhchoci.html


咨詢
建站咨詢
