作用域鏈延長

上篇文章對作用域和作用域鏈的基本概念有了一個詳細的介紹灭必,但是因為篇幅的原因沒有講解延長作用域鏈和塊級作用域稍浆,所以在這篇文章打算將這兩塊知識點進行補充炫惩。

延長作用域鏈

一般來說挤牛,執(zhí)行上下文中的作用域鏈是不會改變的臭家,但是在JS中忽匈,withtry-catch語句可以臨時的延長作用域鏈房午。

with語句

with語句為了簡化多次編寫訪問同一對象的工作,將一個特定的變量對象存儲到作用域鏈的最上層丹允。下面來看一個JavaScript高級程序設計上面的一個例子:

function buildUrl(){
    var qs = "?debug=true";
    with(location){
        var url = href + qs;
    }
    return url;
}
console.log(buildUrl());//file:///C:/Users/Administrator/Desktop/%E7%8E%8B%E8%A7%82%E5%B9%B3/cityPicker/demo1.html?debug=true

在上面這段代碼中郭厌,with語句將location對象提升到了作用域鏈的最前端,那么原先的activation object就被處于第location對象的下方雕蔽。由于with關聯(lián)了location對象折柠,所以location在with內部相當于window對象的地位,甚至在用法方面也是一樣批狐,獲取location里面的屬性可以省略掉location扇售。JavaScript引擎對變量的處理方式是先查找該對象的屬性,如果是嚣艇,則停止查找承冰,如果不是,則繼續(xù)沿著作用域鏈查找食零。

從前面的說明中可以看出with的作用就是簡化代碼困乒,但是由于其將函數(shù)執(zhí)行時處于作用域鏈最前端的對象擠下一層沮榜,這樣會導致查詢的性能變慢补鼻;同時使用with語句還會帶來語義不明的問題,如下面代碼所示:

function fn(a,b){
    with(a){
        console.log(b);
    }
}

調用fn函數(shù)的時候饿敲,輸出來的b可能是a對象里面的b屬性冈爹,也可能是傳入的參數(shù)b涌攻,還有可能是undefined,造成代碼的難以理解频伤;同時with語句會造成潛在的bug恳谎,具體代碼如下面所示:

function fn(obj){
    with(obj){
        a = 1;
    }
};
var obj1 = {
    a:2
};
var obj2 = {
    b:3
};
fn(obj1);
fn(obj2);
console.log(obj1.a);//1
console.log(obj2.a);//undefined
console.log(a);//1

在上面的代碼中不難理解,在fn函數(shù)中憋肖,由于傳入的obj2沒有a屬性因痛,所以會將a屬性自動升級為全局變量(這與不加var字符串就直接聲明變量的原理是一樣的,即變量提升)岸更,而傳入的obj1中有a屬性鸵膏,就會修改obj1中的a屬性。所以怎炊,盡管with能夠延長作用域鏈谭企,但是由于其自身的缺陷導致在項目中使用并不高廓译。

try-catch語句

try-catch語句在JavaScript中用來處理異常,在catch(e){}中的錯誤對象組成了一個新的變量對象然后被加到了作用域的最前端债查。try-catch是個非常有用的語句非区,但是在使用前我們應當了解可能出現(xiàn)的錯誤。同時盹廷,我們可以簡化代碼來使catch子句對性能的影響最小化征绸,我們可以使用一個函數(shù)來處理錯誤,如下面代碼所示:

try{
    fn();
}catch(ex){
    handleError(ex);
}
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末俄占,一起剝皮案震驚了整個濱河市管怠,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌缸榄,老刑警劉巖渤弛,帶你破解...
    沈念sama閱讀 207,248評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異碰凶,居然都是意外死亡暮芭,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評論 2 381
  • 文/潘曉璐 我一進店門欲低,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人畜晰,你說我怎么就攤上這事砾莱。” “怎么了凄鼻?”我有些...
    開封第一講書人閱讀 153,443評論 0 344
  • 文/不壞的土叔 我叫張陵腊瑟,是天一觀的道長。 經(jīng)常有香客問我块蚌,道長闰非,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,475評論 1 279
  • 正文 為了忘掉前任峭范,我火速辦了婚禮财松,結果婚禮上,老公的妹妹穿的比我還像新娘纱控。我一直安慰自己辆毡,他們只是感情好,可當我...
    茶點故事閱讀 64,458評論 5 374
  • 文/花漫 我一把揭開白布甜害。 她就那樣靜靜地躺著舶掖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪尔店。 梳的紋絲不亂的頭發(fā)上眨攘,一...
    開封第一講書人閱讀 49,185評論 1 284
  • 那天主慰,我揣著相機與錄音,去河邊找鬼鲫售。 笑死河哑,一個胖子當著我的面吹牛,可吹牛的內容都是我干的龟虎。 我是一名探鬼主播璃谨,決...
    沈念sama閱讀 38,451評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鲤妥!你這毒婦竟也來了佳吞?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,112評論 0 261
  • 序言:老撾萬榮一對情侶失蹤棉安,失蹤者是張志新(化名)和其女友劉穎底扳,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體贡耽,經(jīng)...
    沈念sama閱讀 43,609評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡衷模,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,083評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了蒲赂。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片阱冶。...
    茶點故事閱讀 38,163評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖滥嘴,靈堂內的尸體忽然破棺而出木蹬,到底是詐尸還是另有隱情,我是刑警寧澤若皱,帶...
    沈念sama閱讀 33,803評論 4 323
  • 正文 年R本政府宣布镊叁,位于F島的核電站,受9級特大地震影響走触,放射性物質發(fā)生泄漏晦譬。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,357評論 3 307
  • 文/蒙蒙 一互广、第九天 我趴在偏房一處隱蔽的房頂上張望敛腌。 院中可真熱鬧,春花似錦兜辞、人聲如沸迎瞧。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽凶硅。三九已至,卻和暖如春扫皱,著一層夾襖步出監(jiān)牢的瞬間足绅,已是汗流浹背捷绑。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留氢妈,地道東北人粹污。 一個月前我還...
    沈念sama閱讀 45,636評論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像首量,于是被迫代替她去往敵國和親壮吩。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,925評論 2 344

推薦閱讀更多精彩內容