按钮不会消失onClick(JavaScript)

时间:2014-04-11 07:14:09

标签: javascript html html5

我有以下代码使按钮不可见,它工作一秒钟,然后再次按钮。导航链接在同一页面上 我试过"返回false;"但是我的导航无法正常工作。

如何隐藏按钮?

的JavaScript

function btn_hide(){

    document.getElementById("btn_shfaqe").style.display="none";
}

HTML

<a href="?tip=fin&vid_id=0" onClick="btn_hide();">test1</a>

5 个答案:

答案 0 :(得分:2)

你必须做两件事;返回函数并返回false,如下所示:

<强>的javascript

function btn_hide(){

    document.getElementById("btn_shfaqe").style.display="none";
    return false;
}

<强> HTML

<a href="?tip=fin&vid_id=0" onClick="return btn_hide();">test1</a>

这是DEMO

根据评论编辑
你最好隐藏服务器按钮,但如果你真的想使用javascript,你可以在页面加载时执行此操作:

function getParameterByName(name) {
    name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
    var regex = new RegExp("[\\?&]" + name + "=([^&#]*)"),
    results = regex.exec(location.search);
    return results == null ? "" : decodeURIComponent(results[1].replace(/\+/g, " "));
}

window.onload = function() {
    var vid_id = getParameterByName('vid_id');
    if (vid_id == 0 || vid_id == 5) {
        document.getElementById("btn_shfaqe").style.display="none";
    }
}

答案 1 :(得分:1)

这是一个锚标签。我将导航到另一页。

如果您不想导航到其他页面,可以使用

javascript:void(0)

as

<a href="javascript:void(0)" onclick="btn_hide();">

答案 2 :(得分:0)

尝试使用javascript:

<script>
    function visibilite() {
        var targetElement = document.getElementById(\'div_connexion\');
        targetElement.style.display = "none";
    }
</script>

,这在html中:

<div id="div_connexion"><a class="connexion" href="javascript:visibilite();">Connexion</a></div>

我在我的网站上有这个,当我点击div时,它会消失,直到用户刷新页面。

答案 3 :(得分:0)

请尝试使用以下代码段。

<head runat="server">
    <title></title>
    <script type="text/javascript">
        function getParameterByName(name) {
            name = name.replace(/[\[]/, "\\[").replace(/[\]]/, "\\]");
            var regex = new RegExp("[\\?&]" + name + "=([^&#]*)"),
        results = regex.exec(location.search);
            return results == null ? "" : decodeURIComponent(results[1].replace(/\+/g, " "));
        }

        function btn_hide() {
            document.getElementById("btn_shfaqe").style.display = "none";
        }
    </script>
</head>
<body>
        <div>
        <button id="btn_shfaqe" style="display: none">
            jayesh</button>
        <a href="?tip=fin&vid_id=0" onclick="btn_hide();">test1</a>
        <script type="text/javascript">
            if (getParameterByName("tip") == "") {
                document.getElementById("btn_shfaqe").style.display = "";
            }
        </script>
    </div>
</body>
</html>

答案 4 :(得分:0)

  

我尝试过的同一页面上导航的链接“返回false;”但是我的导航无效。

您想要隐藏链接仍能导航?

有两种方法可以解决问题:

  1. 服务器端:在您的网址中添加一个参数,如下所示:?tip=fin&vid_id=0&hideButton=1如果已设置,则在服务器端将display: none;样式应用于您的元素。如果你正在使用PHP,那么下面的内容应该可以解决问题:

    <?php if (isset($_GET['hideButton'])) { echo 'style="display: none;"'; }

  2. 客户端:单击按钮时,将一些标记值写入localStorage。加载页面时,检查是否设置了标志。如果已设置 - 隐藏锚点。

    // Onclick handler:
    myButton.addEventListener('click', function () {
        localStorage.setItem('hideButton', 'yes');
    }, false);
    
    // Onload handler:
    window.addEventListener('load', function () {
        if (localStorage.getItem('hideButton') === 'yes') {
            myButton.style.display = 'none';
        }
    });
    
  3. 使用其中一种方法将隐藏链接,同时保持导航工作。您甚至不需要在onclick事件处理程序中隐藏按钮。