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

问题情况

JS中设置window.location.href跳转无效

代码如下:

1
2
3
4
5
6
7
8
<script type="text/javascript">
   function checkUser()
{
     if(2!=1){
        window.location.href="login.jsp"
     }
}
  </script>
  

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

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

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

解决方法一

在js函数中加上

window.event.returnValue=false

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

改成如下代码后window.location.href成功跳转:

1
2
3
4
5
6
7
8
9
<script type="text/javascript">
   function checkUser()
{
     if(2!=1){
        window.location.href="login.jsp"
     window.event.returnValue=false;
     }
}
  </script>
  

解决方法二

点击事件中 onclick="checkUser()" 变成onclick="return checkUser();"

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

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
<script type="text/javascript">
   
   function checkUser()
{
     if(<%=flag%>!=1){
        window.location.href="login.jsp";
     return false;
     }
}
  </script>
  
原文地址:https://www.cnblogs.com/everest33Tong/p/5848261.html