Javascript中使用A標簽獲取當前目錄的絕對路徑方法
來源:易賢網(wǎng) 閱讀:1184 次 日期:2015-03-06 11:49:31
溫馨提示:易賢網(wǎng)小編為您整理了“Javascript中使用A標簽獲取當前目錄的絕對路徑方法”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了Javascript中使用A標簽獲取當前目錄的絕對路徑方法,本文講解的方法比較特別,需要的朋友可以參考下

一談到路徑相關(guān)的問題,大家都會往window.location上想,確實這個對象提供了相當多的路徑信息,其中常用的就包括:

1.location.href:當前頁面的完整URL

2.location.pathname:當前URL中的路徑名

3.location.hash:當前URL中的錨點

4.location.search:當前URL中的查詢參數(shù)

然而,location沒有一個屬性能直接獲得當前目錄(不含文件名)的絕對路徑。通過Google我發(fā)現(xiàn)了一些錯誤的方法,比如說把URL通過“/”分離成數(shù)組,把數(shù)組的最后一項去掉以后再連接成字符串。但如果URL中沒有指定文件名,結(jié)果就大錯特錯了。

根據(jù)以往編碼的經(jīng)驗,a元素的href屬性總是會返回絕對路徑,也就是說它具有把相對路徑轉(zhuǎn)成絕對路徑的能力。使用下面的代碼嘗試了一下,果然成了:

代碼如下:

var a = document.createElement('a');

a.href = './';

alert(a.href);

a = null;

很不幸地,此方法在老舊的IE 6/7下無效,當執(zhí)行alert(a.href)時,彈出的仍然是“./”。后來,我發(fā)現(xiàn)在Stackoverflow上也有人提出了這個問題,而解決方法也是很簡單的,只要把a通過innerHTML注入就可以了:

代碼如下:

var div = document.createElement('div');

div.innerHTML = '<a href="./"></a>";

alert(div.firstChild.href);

div = null;

有人可能會問:為何不用正則表達式?我的答案是:要考慮有無文件名的情況、有無錨點的情況、有無查詢參數(shù)的情況,這條正則表達式可能會挺復雜的。

更多信息請查看IT技術(shù)專欄

更多信息請查看腳本欄目
易賢網(wǎng)手機網(wǎng)站地址:Javascript中使用A標簽獲取當前目錄的絕對路徑方法

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)