成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Javascript中的循環變量聲明,到底應該放在哪兒?

開發 前端
不放走任何一個細節。相信很多Javascript開發者都在聲明循環變量時猶 豫過var i到底應該放在哪里:放在不同的位置會對程序的運行產生怎樣的影響?哪一種方式符合Javascript的語言規范?哪一種方式和ecma標準未來的發展 方向匹配?本文將對四種常見的聲明循環變量的書寫方式進行簡單的分析和比較。

不放走任何一個細節。相信很多Javascript開發者都在聲明循環變量時猶 豫過var i到底應該放在哪里:放在不同的位置會對程序的運行產生怎樣的影響?哪一種方式符合Javascript的語言規范?哪一種方式和ecma標準未來的發展 方向匹配?本文將對四種常見的聲明循環變量的書寫方式進行簡單的分析和比較。

 

[[151894]]

習慣1:不聲明直接使用

 

  1. function loop(arr) { 
  2.     for (i = 0; i < arr.length; i++) { 
  3.         // do something 
  4.     } 

非常危險的使用習慣,一般情況下循環變量將成為window對象上的一個屬性被全局使用,極有可能影響程序的正常邏輯實現,想想都蛋疼,大家都懂的,就不在這里贅述了。
需要著重提一下的是,在strict模式下,未聲明變量而直接賦值的使用方式會直接拋出異常,早就該這么做啦!引用一下ecma-262標準附錄C中的一段話:
"Assignment to an undeclared identifier or otherwise unresolvable reference does not create a property in the global object. When a simple assignment occurs within strict mode code, its LeftHandSide must not evaluate to an unresolvable Reference. If it does a ReferenceError exception is thrown (6.2.3.2)."
換言之,如果再使用未經聲明的變量的話,ReferenceError異常會被拋出。

習慣2:放在for循環初始語句塊中并反復聲明

  1. function loop(arr) { 
  2.     for (var i = 0; i < arr.length; i++ ){ 
  3.         // do someting 
  4.     } 
  5.     // console.log(i); 
  6.     for (var i = 0; i < arr.length; i++ ){ 
  7.         // do something else 
  8.     } 

這種方式看似最安全規范,很多從C和Java轉到前端開發的同學都偏愛這樣的寫法,事實上,這也許是由于對Javascript中一個重要概念有所 誤解造成的——變量作用域。不同于C和Java,Javascript并不具備真正的塊級作用域,也就是說,在第一個循環結束之 后,console.log(i)并不會打印undefined或者拋出ReferenceError異常,而是會正常打印出arr.length。
當 然,這樣的寫法雖然除了美觀以外意義不大,但是長久以來兼容性良好且沒有違反任何規范——ecma標準中并沒有禁止在某一個作用域內對于同一變量的重復聲 明。不僅如此,其實這里還有一個另外好消息,在ECMAScript 6中,一個新的,為支持真正的塊級作用域而生的關鍵字出現了——let。這里放一個傳送門,有興趣的同學可以自行了解:
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let

習慣3:在函數頂部和其他變量一起集中定義

  1. function loop(arr) { 
  2.     var var1; 
  3.     var var2; 
  4.     var i; 
  5.  
  6.     for (i = 0; i < arr.length; i++) { 
  7.         // do something 
  8.     } 

這種c89-like式的變量定義方式在Javascript中幾乎無可挑剔,既不會造成Javascript支持塊級作用域的誤解,又不會污染全 局scope,還不違反任何標準和規范,主要缺點就是循環變量的聲明和循環體可能會隔開比較遠。在不借助更多代碼的前提下,除了等待各大主流瀏覽器廠商實 現ECMAScript 6中的let關鍵字以外,這個問題似乎找不到更好的解決方案。

習慣4:將循環代碼封裝到IIFE中

 

  1. function loop(arr) { 
  2.     (function () { 
  3.         for (var i = 0; i < arr.length; i++) { 
  4.             // do something 
  5.         } 
  6.     })(); 
  7. }

最后一種習慣是前端程序員們熟悉的IIFE(Immediately-Invoked Function Expression),即立即執行函數。此種方法的主要缺點是書寫相對麻煩,且有多余的性能損耗(很?。?,但在兼容性、對各標準規范的遵循上表現良好。 如果不嫌麻煩,開發者可以采取這種方式。

以上就是對Javascript中四種常見循環變量定義書寫習慣的簡單介紹和分析,各有利弊,讀者可以結合自己的需求擇優使用。應該說,在 ECMAScript 6之前并沒有一種定義循環變量的完美解決方案。好在ECMAScript標準委員會也及時發現了這個問題,讓我們一起期待let關鍵字吧。

責任編輯:王雪燕 來源: 博客園
相關推薦

2016-01-12 17:10:56

嫦娥玉兔美照

2011-12-12 13:09:45

云計算

2018-08-31 08:51:31

C 語言開發編程

2015-08-27 13:45:25

2023-09-12 11:38:18

2019-07-23 16:00:36

區塊鏈存儲5G

2022-02-25 10:03:11

對象數據算法

2010-06-23 09:41:17

Amazon Simp

2021-02-19 10:40:48

HashMap線程Java

2021-12-01 07:26:12

AIOps企業

2013-12-04 09:33:15

軟件成本

2014-04-17 10:16:50

2013-05-10 10:58:56

ERP

2020-02-11 17:15:09

開發者拋棄 Executors

2020-02-13 09:14:16

Executors開發Java

2020-04-21 16:01:13

自動駕駛新基建工信部

2017-10-11 11:17:16

SaaS出路中國式

2020-03-25 09:20:21

自然語言處理

2012-10-25 16:40:11

WOT高效數據中心數據中心

2015-01-08 14:52:29

google云計算分布式計算框架
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产91精品久久久久久久网曝门 | 亚洲精品电影 | 久久人人国产 | 亚洲一区二区视频 | аⅴ资源新版在线天堂 | 韩国成人在线视频 | 亚洲h在线观看 | 韩国电影久久 | 亚洲精品电影 | 精品一区二区三区免费视频 | 九九热视频这里只有精品 | 亚洲精品68久久久一区 | 久久精品免费 | 久久国产精品网站 | 国产欧美在线一区二区 | 伊人影院在线观看 | 羞羞的视频免费观看 | 一区二区三区免费在线观看 | 国产精品久久久亚洲 | 久久99精品久久久 | 日韩欧美中文字幕在线观看 | 成人免费视频播放 | av香蕉 | 狠狠干在线 | 九九热精品在线 | 青青草一区 | 日韩高清在线 | 久久久久久久久中文字幕 | 希岛爱理在线 | 免费看啪啪网站 | 日日操视频 | 成人精品一区二区三区中文字幕 | 国产在线一区二区 | 国产免费一区二区三区网站免费 | 精品国产一区二区在线 | 91精品国产99久久 | 亚洲一区二区视频 | 亚洲人成人一区二区在线观看 | 99re热这里只有精品视频 | 欧美美女一区二区 | 色.com|