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

Javascript , is there a way to make the javascript disable all links except one

本文关键字:链接 一个 有没有 JavaScript Javascript      更新时间:2023-09-26

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

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

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

使用您拥有的脚本作为示例,只需设置一个条件。我使用了此处描述的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文件,它可以工作。唯一应该有效的链接是:谷歌,雅虎和必应。Apple,Catmoji和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>

您需要找到您不想禁用的链接的某些属性,然后在循环时检查该属性。例如,如果图像和菜单链接#作为其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;

值得一提的是,在没有充分理由的情况下禁用/重定向一堆链接是激怒用户并使他们永远不会返回您的网站的好方法。

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

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

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