0

JSを使用してドキュメントヘッドにベースURLタグを追加しているので、ページ上の相対リンクが機能します。しかし、それは有効にならず、Firebug(Firefoxのデバッグアドオン)は<BASE />要素をグレー表示します。なぜですか?これは、Firefoxがそれを理解できない、または構文が正しくないことを意味しますか?

画像http://www.freeimagehosting.net/uploads/a3122c1ddd.png

4

1 に答える 1

1

http://www.w3schools.com/TAGS/tag_base.asp

ベースタグには、hrefとtargetの2つのコンポーネントがあります。あなたは元気そうです。あなたはそれが失敗しているリンクのいくつかの例を挙げますか?

デモについては、http://ashita.org/StackOverflow/base_test.htmlを参照してください。(私のテスト)

編集:コメントを見る

function addBase(url) {
    var regex = /^(https?|ftp):\/\//;

    var a = Array.prototype.slice.call(document.getElementsByTagName('a'),0);
    var link = Array.prototype.slice.call(document.getElementsByTagName('link'),0);
    var script = Array.prototype.slice.call(document.getElementsByTagName('script'),0);
    var img = Array.prototype.slice.call(document.getElementsByTagName('img'),0);

    var hrefs = a.concat(link);
    var srcs = img.concat(script);

    var element,href,src;
    for (var i=0,len=hrefs.length;i<len;++i) {
        element = hrefs[i];
        href = element.getAttribute("href");
        if (href) {
            if (!regex.test(href)) {
                href = (url + "/" + href).replace("//","/"); //to handle double slash     collision
                element.setAttribute("href",href);
            }
        }
    }
    for (var i=0,len=srcs.length;i<len;++i) {
        element = srcs[i];
        src = element.getAttribute("src");
        if (src) {
            if (!regex.test(src)) {
                src = (url + "/" + src).replace("//","/"); //to handle double slash     collision
                element.setAttribute("src",src);
            }
        }
    }
}

Firefoxでテストおよび作業中

于 2009-05-28T11:14:51.627 に答える