使用Javascript編寫getabsolutepath工具函數,讓URL路徑獲取更加便捷

每個前端開發都會遇到獲取當前頁面的完整路徑的情況,特別是在製作單頁面應用時。通常情況下,我們會使用JavaScript自帶的方法location.href來獲取當前頁面的路徑,但是這種方式也存在一些問題,比如說獲取的路徑不是絕對路徑,在單頁面應用中可能會導致路徑出錯。在這篇文章中我們將介紹一個名為getAbsolutePath的函數,它可以更加方便地獲取絕對路徑。

一、函數實現

function getAbsolutePath(path) {
  var a = document.createElement('a');
  a.href = path;
  return a.href;
}

這個函數接受一個參數 path,這個參數可以是相對路徑或絕對路徑。函數內部創建了一個a標籤,然後將路徑賦值給a標籤的href屬性,再將這個a標籤的href屬性返回,這個href屬性已經被瀏覽器自動解析成完整路徑了。

接下來我們來試試getAbsolutePath函數的效果,假設我們有一個相對路徑”../images/logo.jpg”,嘗試使用getAbsolutePath函數把這個相對路徑解析成絕對路徑。

var path = '../images/logo.jpg';
var absolutePath = getAbsolutePath(path);
console.log(absolutePath);

上述代碼將輸出完整的絕對路徑,包括協議、主機名、端口號以及文件路徑。

二、兼容性問題

上面的getAbsolutePath函數在絕大多數現代瀏覽器中都能夠正常運行,但是一些老舊的瀏覽器(如IE6~IE7)會出現一些兼容性問題。

當a標籤的href屬性被賦值為相對路徑時,較新的瀏覽器會自動將其解析為絕對路徑,而早期的瀏覽器則不具備這個功能。因此,在一些老版本的瀏覽器中,我們需要手動將相對路徑解析成絕對路徑,方法是先獲取當前頁面的絕對路徑,然後將相對路徑拼接在其後,這種方法的實現如下:

function getAbsolutePath(path) {
  var currentUrl = window.location.href;
  var url = path;
  if(path.indexOf("/") !== 0) {
    url = currentUrl.substring(0, currentUrl.lastIndexOf("/") + 1) + path;
  }
  var a = document.createElement('a');
  a.href = url;
  return a.href;
}

這裡的代碼判斷了傳遞進來的路徑是否以”/”字符開頭,如果是相對路徑則嘗試拼接成絕對路徑,否則直接解析傳入的路徑。這樣做,我們就可以兼容大部分舊版本瀏覽器了。

三、拓展應用

在實際的開發中,我們常常需要根據當前頁面的絕對路徑動態獲取其它資源的路徑,比如圖片或文件的路徑。為了方便我們動態生成這些路徑,我們可以把獲取絕對路徑的方法封裝成一個通用的函數,比如下面的getSiteUrl函數:

function getSiteUrl(path) {
  var currentUrl = window.location.href;
  var url = path;
  if(path.indexOf("/") !== 0) {
    url = currentUrl.substring(0, currentUrl.lastIndexOf("/") + 1) + path;
  }
  var a = document.createElement('a');
  a.href = url;
  return a.href;
}

function getImageUrl(url) {
  return getSiteUrl("/assets/images/" + url);
}

function getCssUrl(url) {
  return getSiteUrl("/assets/css/" + url);
}

function getJsUrl(url) {
  return getSiteUrl("/assets/js/" + url);
}

這裡我們將通用的getSiteUrl方法和具體的getImageUrl、getCssUrl、getJsUrl方法分別封裝到了不同的函數中,以方便我們動態生成對應的資源路徑,比如:

var logoUrl = getImageUrl("logo.png");
var cssUrl = getCssUrl("style.css");
var jsUrl = getJsUrl("app.js");

這些函數可以更加方便地讓我們生成資源路徑,避免了重複寫絕對路徑的繁瑣過程。

結語

getAbsolutePath這個函數雖然看似簡單,但其實包含了許多前端開發中常見的問題。寫這篇文章的目的也是希望可以給各位前端開發者提供一些思路和方法,讓大家在開發中更加得心應手。同時,我們也要時刻注意兼容性問題,不同瀏覽器有着不同的特點和限制,只有不斷學習和實踐,我們才能在不斷變化的技術環境中立足。

原創文章,作者:PQGM,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/132033.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
PQGM的頭像PQGM
上一篇 2024-10-03 23:49
下一篇 2024-10-03 23:49

相關推薦

  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python中capitalize函數的使用

    在Python的字符串操作中,capitalize函數常常被用到,這個函數可以使字符串中的第一個單詞首字母大寫,其餘字母小寫。在本文中,我們將從以下幾個方面對capitalize函…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29
  • Python中set函數的作用

    Python中set函數是一個有用的數據類型,可以被用於許多編程場景中。在這篇文章中,我們將學習Python中set函數的多個方面,從而深入了解這個函數在Python中的用途。 一…

    編程 2025-04-29
  • 單片機打印函數

    單片機打印是指通過串口或並口將一些數據打印到終端設備上。在單片機應用中,打印非常重要。正確的打印數據可以讓我們知道單片機運行的狀態,方便我們進行調試;錯誤的打印數據可以幫助我們快速…

    編程 2025-04-29
  • 三角函數用英語怎麼說

    三角函數,即三角比函數,是指在一個銳角三角形中某一角的對邊、鄰邊之比。在數學中,三角函數包括正弦、餘弦、正切等,它們在數學、物理、工程和計算機等領域都得到了廣泛的應用。 一、正弦函…

    編程 2025-04-29
  • Python3定義函數參數類型

    Python是一門動態類型語言,不需要在定義變量時顯示的指定變量類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

    編程 2025-04-29
  • Python定義函數判斷奇偶數

    本文將從多個方面詳細闡述Python定義函數判斷奇偶數的方法,並提供完整的代碼示例。 一、初步了解Python函數 在介紹Python如何定義函數判斷奇偶數之前,我們先來了解一下P…

    編程 2025-04-29
  • Python實現計算階乘的函數

    本文將介紹如何使用Python定義函數fact(n),計算n的階乘。 一、什麼是階乘 階乘指從1乘到指定數之間所有整數的乘積。如:5! = 5 * 4 * 3 * 2 * 1 = …

    編程 2025-04-29

發表回復

登錄後才能評論