JS中设置window.location.href跳转无效(在a标签里或这form表单里)

文章目录


代码如下:

 <li><a href="myblog.html" onclick="checkLogin()">博客管理</a></li>
 function checkLogin() {
        var user_id=getCookiesPbyName("user_id");
        if (user_id == null || user_id == ""){
            alert("该页面需登陆以进入!");
            window.location.href = "login.html";
            window.event.returnValue=false;
        }
    }

原因:
a标签的href跳转会执行在window.location.href设置的跳转之前:

如果是表单form的话 也会先执行form提交。

提交之后 就已经不在当前页面了。所以window.location.href无效。

解决:

方法一:
在js函数中加上

window.event.returnValue=false

这个属性放到提交表单中的onclick事件中在这次点击事件不会提交表单,如果放到超链接中则在这次点击事件不执行超链接href属性。


修改后的代码:

 function checkLogin() {
        var user_id=getCookiesPbyName("user_id");
        if (user_id == null || user_id == ""){
            alert("该页面需登陆以进入!");
            window.location.href = "login.html";
            window.event.returnValue=false;
        }
    }

方法二:
点击事件中 οnclick=“checkLogin()” 变成οnclick=“return checkLogin();”

并且在checkLogin中 return false;这样的话 a标签的href也不会执行。 这样就能window.location.href顺利跳转。

代码如下:

 <li><a href="myblog.html" onclick="return checkLogin()">博客管理</a></li>
<script type="text/javascript">
    function checkLogin() {
        var user_id=getCookiesPbyName("user_id");
        if (user_id == null || user_id == ""){
            alert("该页面需登陆以进入!");
            window.location.href = "login.html";
           return false;
        }
    }
  </script>
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值