使用Javascript獲取當前目錄的絕對路徑

2021-06-18 19:53:37 字數 847 閱讀 4765

一談到路徑相關的問題,大家都會往window.location上想,確實這個物件提供了相當多的路徑資訊,其中常用的就包括:

location.href:當前頁面的完整url

location.pathname:當前url中的路徑名

location.hash:當前url中的錨點

location.search:當前url中的查詢引數

然而,location沒有乙個屬效能直接獲得當前目錄(不含檔名)的絕對路徑。通過google我發現了一些錯誤的方法,比如說把url通過「/」分離成陣列,把陣列的最後一項去掉以後再連線成字串。但如果url中沒有指定檔名,結果就大錯特錯了。

根據以往編碼的經驗,我記得a元素的href屬性總是會返回絕對路徑,也就是說它具有把相對路徑轉成絕對路徑的能力。使用下面的**嘗試了一下,果然成了:

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

a.href = './';

alert(a.href);

a = null;

很不幸地,此方法在老舊的ie 6/7下無效,當執行alert(a.href)時,彈出的仍然是「./」。後來,我發現在stackoverflow上也有人提出了這個問題,而解決方法也是很簡單的,只要把a通過innerhtml注入就可以了:

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

div.innerhtml = '";

alert(div.firstchild.href);

div = null;

有人可能會問:為何不用正規表示式?我的答案是:要考慮有無檔名的情況、有無錨點的情況、有無查詢引數的情況,這條正規表示式可能會挺複雜的。

javascript獲取型別

1 使用typeof函式可以用於識別運算數型別的字串,可以返回如下型別 number,string,boolenan,object,function,undefined.2 當使用typeof函式檢測null值時,返回的時object,則需要 return o null null typeof o ...

JavaScript屬性獲取

一 操作標籤的合法屬性 合法屬性 比如id class title href src等。獲取合法屬性 獲取元素之後,直接使用點語法。修改合法屬性 獲取元素之後,用等號賦值,修改已有屬性。新增合法屬性 直接等號賦值。id box title 你好 你好嗎?div var title document....

JavaScript獲取節點

可以把html中的每個標籤看成乙個節點,那麼可以通過js將這些節點獲取出來,可以使用js的乙個內建物件 物件有自己的屬性和方法 取得這些節點並且進行操作 修改,刪除,替換其內容 該物件是乙個內建物件叫作document,內建物件就是已經建立好的物件,我們可以直接使用。瀏覽器標題欄 title 引用外...