關(guān)于引用 js 文件走芋,我有話說

首先,我引用一個(gè) testFunction.js 的文件潘鲫,里面的代碼如下:

function shallwego() {
    return true
}
function gotopage1() {
    if (shallwego) {
        window.location = "http://www.reibang.com/p/dc062dd46e17"
    }
}
gotopage1();
function gotopage2() {
        m += 1;
    }
gotopage2();

然后我在 html 文件( index.html )當(dāng)中翁逞,引入上述 js 文件,代碼如下:

<script src="../js/testFunction.js"></script>

然后文件的相對(duì)位置給你展示一下:


文件相對(duì)位置

看到這里溉仑,我想問你一個(gè)問題挖函,如果我打開 index.html,結(jié)果會(huì)是什么樣的呢彼念?
先猜一下挪圾,不要說出來,
然后看下圖逐沙,看看和你想的結(jié)果是不是一樣的呢哲思?
為了方便打開頁面,我直接在網(wǎng)址中輸入本地文件的地址:

http://localhost:63342/learnnode/html/index.html?_ijt=alk3vcpo52stc41djq106cpn51





咦吩案?控制臺(tái)好像有一個(gè)錯(cuò)誤棚赔?看不清?
放大來看一些:


錯(cuò)誤報(bào)告

你可能會(huì)有疑問了,這不是 js 文件中關(guān)于第三個(gè)函數(shù)的報(bào)錯(cuò)嗎靠益?
可是我明明在第二個(gè)函數(shù)調(diào)用的時(shí)候丧肴,
就已經(jīng)通過 window.location 跳轉(zhuǎn)到其他頁面了呀,
怎么會(huì)繼續(xù)執(zhí)行原來 js 文件里面的函數(shù)呢胧后?

你可能想當(dāng)然的以為芋浮,第三個(gè)函數(shù)不會(huì)執(zhí)行,而是第二個(gè)函數(shù)執(zhí)行完了之后壳快,直接 window.location = "…"就跳轉(zhuǎn)走了纸巷。
但是實(shí)際上,在引用 js 文件的時(shí)候眶痰,你可以把它理解成瘤旨,這個(gè) js 文件相當(dāng)于一個(gè)大的函數(shù),不過竖伯,這個(gè)函數(shù)沒辦法 return存哲。 所以,在執(zhí)行引用的 js 文件的時(shí)候七婴,他不會(huì)看你其中的某個(gè)函數(shù)是否會(huì)有類似于中斷的功能(例如祟偷,window.location = “…”)。
他會(huì)一次性把所有的函數(shù)都過一遍之后本姥,再執(zhí)行其中的某個(gè)函數(shù)肩袍。

這就是為什么,明明在 js 文件中第二個(gè)函數(shù)是跳轉(zhuǎn)婚惫,反而第三個(gè)函數(shù)也會(huì)「執(zhí)行」氛赐,導(dǎo)致報(bào)錯(cuò)的根本原因。


那么先舷,知道了問題出在了哪里艰管,該如何解決呢?

第一種方法:拆分成兩部分蒋川,然后放到兩個(gè) js 文件中牲芋。如下圖:


方法一

我們?cè)俚綖g覽器中看一下,看看控制臺(tái)這次會(huì)不會(huì)報(bào)錯(cuò):



怎么樣捺球?是不是好了呢缸浦?

我們?cè)賮砜吹诙N方法:
我們可以通過判斷語句來達(dá)到類似于「控制代碼執(zhí)行」的作用,代碼如下:

function shallwego() {
    return true
}

function gotopage1() {
    if (shallwego) {
        window.location = "http://www.reibang.com/p/dc062dd46e17"
    }
}

if (true) {
    gotopage1()
} else {
    function gotopage2() {
        m += 1;
    }
    gotopage2()
}

效果也是一樣的氮兵,你可以試一下裂逐。我這邊就不附圖了~

方法三:借用立即執(zhí)行函數(shù)

function shallwego() {
    return true
}
(function() {
    if (shallwego) {
        window.location = "http://www.reibang.com/p/dc062dd46e17"
    }
}());

function gotopage2() {
    m += 1;
}
gotopage2();

立即執(zhí)行函數(shù)的好處是,可以在函數(shù)創(chuàng)建完之后就立刻調(diào)用泣栈。
不過我在實(shí)際使用的時(shí)候卜高,發(fā)現(xiàn)并沒有解決問題弥姻,報(bào)錯(cuò)還是一樣出現(xiàn):


錯(cuò)誤好像還沒有消失

可能是我的寫法不對(duì),
我有時(shí)間的話會(huì)研究一下關(guān)于立即執(zhí)行函數(shù)有關(guān)的知識(shí)掺涛。


最后庭敦,歡迎優(yōu)秀的你給我提出寶貴的意見和建議。
我會(huì)不斷的堅(jiān)持薪缆,將自己打磨的越來越優(yōu)秀秧廉。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市矮燎,隨后出現(xiàn)的幾起案子定血,更是在濱河造成了極大的恐慌,老刑警劉巖诞外,帶你破解...
    沈念sama閱讀 221,273評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異灾票,居然都是意外死亡峡谊,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門刊苍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來既们,“玉大人,你說我怎么就攤上這事正什∩吨剑” “怎么了?”我有些...
    開封第一講書人閱讀 167,709評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵婴氮,是天一觀的道長斯棒。 經(jīng)常有香客問我,道長主经,這世上最難降的妖魔是什么荣暮? 我笑而不...
    開封第一講書人閱讀 59,520評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮罩驻,結(jié)果婚禮上穗酥,老公的妹妹穿的比我還像新娘。我一直安慰自己惠遏,他們只是感情好砾跃,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,515評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著节吮,像睡著了一般抽高。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上课锌,一...
    開封第一講書人閱讀 52,158評(píng)論 1 308
  • 那天厨内,我揣著相機(jī)與錄音祈秕,去河邊找鬼。 笑死雏胃,一個(gè)胖子當(dāng)著我的面吹牛请毛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播瞭亮,決...
    沈念sama閱讀 40,755評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼方仿,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了统翩?” 一聲冷哼從身側(cè)響起仙蚜,我...
    開封第一講書人閱讀 39,660評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎厂汗,沒想到半個(gè)月后委粉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡娶桦,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,287評(píng)論 3 340
  • 正文 我和宋清朗相戀三年贾节,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片衷畦。...
    茶點(diǎn)故事閱讀 40,427評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡栗涂,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出祈争,到底是詐尸還是另有隱情斤程,我是刑警寧澤,帶...
    沈念sama閱讀 36,122評(píng)論 5 349
  • 正文 年R本政府宣布菩混,位于F島的核電站忿墅,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏墨吓。R本人自食惡果不足惜球匕,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,801評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望帖烘。 院中可真熱鬧亮曹,春花似錦、人聲如沸秘症。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽乡摹。三九已至役耕,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間聪廉,已是汗流浹背瞬痘。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評(píng)論 1 272
  • 我被黑心中介騙來泰國打工故慈, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人框全。 一個(gè)月前我還...
    沈念sama閱讀 48,808評(píng)論 3 376
  • 正文 我出身青樓察绷,卻偏偏與公主長得像,于是被迫代替她去往敵國和親津辩。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拆撼,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,440評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容