在requireJS中,有一個屬性叫baseURL,透過設定baseURL,我們可以將需要載入的檔案路徑寫成相對於專案的,而不是相對於目前的頁面。
例如:假設我們的專案目錄是/myproject/,裡面有兩個頁面,一個是/myproject/one.html,另一個是/myproject/html/other.html,他們都要載入/myproject/js /some.js。如果我們將baseURL設定成/myproject/,則我們在載入該js的時候,這兩個頁面都可以使用相對於專案的路徑./js/some,而不是因為頁面的路徑不同而使用不同的相對路徑。
但是如果不使用requireJS,我們能不能實作類似baseURL的功能呢?
base標籤
其實,HTML中有一個base標籤,可以產生類似的功能。舉例:
我們會發現,我們用相對路徑./images/logo_gray.gif載入的圖片,卻變成了http://static.cnblogs.com/images/logo_gray.gif的圖片。
base標籤可以為頁面的連結加上預設的路徑,或是預設的開啟方式。
下面是一個設置默認打開方式的例子:
Chrome的載入正常。
Firefox的載入不正常。
Why?
這個我們並沒有找到很好的解釋,我們的分析是瀏覽器對資源加載進行了優化,導致動態插入base標籤並未生效時,就預先去加載了,結果出錯,然後base標籤生效於是又加載正確的資源。
如何避免呢? 不動態寫入base標籤就沒有任何問題。如果需要動態寫入base標籤,那麼頁面所有引用的外部資源都需要透過Javascript動態載入。