自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

JavaScript中同名標(biāo)識符優(yōu)先級詳解

開發(fā) 前端
本文詳細(xì)解讀JavaScript中同名標(biāo)識符優(yōu)先級,給初學(xué)者提供學(xué)習(xí)和幫助。

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

  1. var x = 1; // --> 外部變量x  
  2. function fn(){  
  3.     alert(x);  // --> undefined 局部變量x先使用  
  4.     var x = 2; // 后聲明且賦值  
  5. }  
  6. fn();  
  7. alert(x); // --> 1<br> 

第一點,函數(shù)fn內(nèi)第一句輸出x,x是在第二句才定義的。這在JS中是允許的,這里的允許是指不會出現(xiàn)語法錯誤程序可以運行。

但在其它語言如C,Java中卻是不允許的。變量必須先聲明后使用,如

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

Java中編譯器會提示錯誤,程序無法運行。

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

二,形參優(yōu)先級高于函數(shù)名

  1. function fn(fn){  
  2.     alert(fn);  
  3. }  
  4. fn('hello'); // --> "hello" 

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

三,形參優(yōu)先級高于arguments

  1. function fn(arguments){  
  2.     alert(arguments);  
  3. }  
  4. fn('hello'); // --> "hello"<br> 

arguments對象可以直接在函數(shù)內(nèi)使用,是語言本身提供的一個 特殊標(biāo)識符 。

這里剛好將形參聲明成與其同名。輸出可以看到是"hello"而非"[object Object]",即形參arguments覆蓋了語言本身提供的真正的arguments。

四,形參優(yōu)先級高于只聲明卻未賦值的局部變量

  1. function fn(a){  
  2.     var a;  
  3.     alert(a);  
  4. }  
  5. fn('hello'); // --> "hello" 

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

五,聲明且賦值的局部變量優(yōu)先級高于形參

  1. function fn(a){  
  2.     var a = 1;  
  3.     alert(a);  
  4. }  
  5. fn('hello'); // --> "1" 

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

六,形參賦值給同名局部變量時

  1. function fn(a){  
  2.     var aa = a;  
  3.     alert(a);  
  4. }  
  5. fn('hello'); 

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

JavaScript中同名標(biāo)識符優(yōu)先級

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

原文鏈接:http://www.cnblogs.com/snandy/archive/2011/03/11/1980399.html

【編輯推薦】

  1. 淺析JavaScript繼承方式
  2. 淺析JavaScript的寫類方式
  3. 如何編寫高質(zhì)量的Javascript代碼
  4. 深入理解JavaScript的閉包特性
  5. JavaScript中大括號“{}”的多義性
責(zé)任編輯:陳貽新 來源: Snandy的博客
相關(guān)推薦

2010-09-01 14:10:36

CSS優(yōu)先級

2009-09-23 10:41:10

對象標(biāo)識符Hibernate

2009-08-12 13:07:13

C#運算符優(yōu)先級

2012-02-08 14:01:18

HibernateJava

2009-08-26 14:01:18

C#標(biāo)識符

2012-08-14 09:38:29

WAN優(yōu)化

2021-04-06 10:45:18

React前端優(yōu)先級

2023-08-08 08:28:03

消息消費端Spring

2024-04-23 14:13:38

開發(fā)配置文件

2017-04-21 12:30:45

AndroidAndroid O設(shè)備標(biāo)識符

2023-11-03 08:22:09

Android系統(tǒng)算法

2022-12-23 09:41:14

優(yōu)先級反轉(zhuǎn)

2009-07-21 08:41:05

Scala操作符優(yōu)先級

2010-09-16 15:32:20

CSS選擇器

2023-05-28 00:09:21

2009-10-27 14:20:37

VB.NET動態(tài)標(biāo)識符

2010-08-31 11:04:48

CSS優(yōu)先級

2009-08-28 17:10:59

C#線程優(yōu)先級

2010-09-13 17:30:07

CSS優(yōu)先級

2022-07-17 06:57:02

時間戳唯一標(biāo)識符
點贊
收藏

51CTO技術(shù)棧公眾號