Javascript,有没有办法让javascript禁用除一个链接之外的所有链接

时间:2013-01-27 00:59:11

标签: javascript html joomla2.5

我想将一个网站上的所有链接重定向到另一个网域。除了很少的菜单链接和网站中的一个图像..所有我能找到的是这个代码,它只是禁用所有链接 任何想法

function disable() {
  links=document.getElementsByTagName('A');
  for(var i=0; i<links.length; i++) {
    links[i].href="javascript:return false";
  }
}
window.onload=disable;

我想展示人们可以下载的大量演示模板,但是这些模板有各种各样的链接,我不想让人们浏览,所以我想在模板中放一个图像,看看更多的模板。这就是我想要启用的唯一链接

3 个答案:

答案 0 :(得分:0)

您需要找到您不希望禁用的链接的某些属性,然后在循环时检查该属性。例如,如果图片和菜单链接的#属性为href

function disableLinks () {
    var allLinks=document.getElementsByTagName('A');

    for(var i=0; i<allLinks.length; i++) {
        if (allLinks[i].href !== '#') {
            allLinks[i].href="javascript:return false";
        }
    }
}

window.onload = disableLinks;

值得一提的是,在没有充分理由的情况下禁用/重定向一堆链接是一种很好的方式来惹恼用户并让他们永远不会回到您的网站。

答案 1 :(得分:0)

使用您拥有的脚本作为示例只需设置条件。我使用了here描述的inArray()函数。基本逻辑是设置一个名为good_links的数组,该数组是您不希望被中和的链接列表。然后使用inArray()函数,disable()函数现在可以逻辑遍历所有链接但忽略good_links

<script type="text/javascript">

    function disable(){
        var good_links = new Array();
        good_links[0] = "http://www.google.com/";
        good_links[1] = "http://www.yahoo.com/";
        good_links[2] = "http://www.bing.com/";
        links=document.getElementsByTagName('A');
        for(var i=0; i<links.length; i++) {
            if (!inArray(links[i].href, good_links)) {
                links[i].href="javascript:return false";
            }
        }
    }

    function inArray(needle, haystack) {
        var length = haystack.length;
        for(var i = 0; i < length; i++) {
            if(haystack[i] == needle) return true;
        }
        return false;
    }

    window.onload=disable;

</script>

好的,这是我的整个HTML文件。唯一可行的链接是:Google,Yahoo&amp;兵。 Apple,Catmoji&amp; StackOverflow被禁用。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title>My Webpage</title>
    <script type="text/javascript">
//<![CDATA[

    function disable(){
        var good_links = new Array();
        good_links[0] = "http://www.google.com/";
        good_links[1] = "http://www.yahoo.com/";
        good_links[2] = "http://www.bing.com/";
        links=document.getElementsByTagName('A');
        for(var i=0; i<links.length; i++) {
            if (!inArray(links[i].href, good_links)) {
                links[i].href="javascript:return false";
            }
        }
    }

    function inArray(needle, haystack) {
        var length = haystack.length;
        for(var i = 0; i < length; i++) {
            if(haystack[i] == needle) return true;
        }
        return false;
    }

    window.onload=disable;

    //]]>
    </script>
</head>

<body>
    <a href="http://www.google.com/">http://www.google.com/</a><br />
    <a href="http://www.apple.com/">http://www.apple.com/</a><br />
    <a href="http://www.yahoo.com/">http://www.yahoo.com/</a><br />
    <a href="http://www.catmoji.com/">http://www.catmoji.com/</a><br />
    <a href="http://www.bing.com/">http://www.bing.com/</a><br />
    <a href="http://www.stackoverflow.com/">http://www.stackoverflow.com/</a>
</body>
</html>

答案 2 :(得分:-1)

如果您正在使用Apache,并且可以区分重定向链接和不重定向链接,则可以调整Apache mod_rewrite规则......

Options +FollowSymLinks
RewriteEngine on
RewriteRule (.*) http://www.domain.com/$1 [R=301,L]

(.*)必须改变,但这是一个开始。