2010-04-20 23 views
7

Więc chcę łączyć ciągi z względnymi adresami URL w Javascript.łączy względne adresy URL?

podstawy URL = "http://www.adress.com/more/evenmore"

z

względnego adresu URL = "../../adress" => "http://www.adress.com/adress"
względem URL = "../adress" => " http://www.adress.com/more/adress "

Jaki byłby najlepszy sposób? Myślałem o używaniu wyrażeń regularnych i sprawdzaniu, ile "../" znajduję, a następnie odejmuję tę wartość od baseurl i dodając je do tego, co zostało.

Odpowiedz

9

Następująca funkcja rozkłada adres URL, a następnie rozwiązuje go.

function concatAndResolveUrl(url, concat) { 
    var url1 = url.split('/'); 
    var url2 = concat.split('/'); 
    var url3 = [ ]; 
    for (var i = 0, l = url1.length; i < l; i ++) { 
    if (url1[i] == '..') { 
     url3.pop(); 
    } else if (url1[i] == '.') { 
     continue; 
    } else { 
     url3.push(url1[i]); 
    } 
    } 
    for (var i = 0, l = url2.length; i < l; i ++) { 
    if (url2[i] == '..') { 
     url3.pop(); 
    } else if (url2[i] == '.') { 
     continue; 
    } else { 
     url3.push(url2[i]); 
    } 
    } 
    return url3.join('/'); 
} 
+0

miłe. dzięki stary! – heffaklump

+1

Zmodyfikowałem to, gdy twoje testy dla "." aby przetestować pusty ciąg 'url1 [i] == '.' || url1 [i] == "", więc jeśli przekazane adresy mają ukośniki, nadal tworzy prawidłowy adres URL. +1 – Jay

6

Korzystanie URI.js (http://medialize.github.com/URI.js/docs.html#absoluteto):

function joinUrl(baseUrl, url) { 
    var theUrl = new URI(url); 
    if (theUrl.is("relative")) { 
     theUrl = theUrl.absoluteTo(baseUrl); 
    } 
    return theUrl.toString(); 
}