javascript 中设置window.location.href跳转无效问题解决办法

javascript 中设置window.location.href跳转无效问题解决办法

问题情况

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

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
<script type="text/javascript">
  function checkUser()
   if(2!=1){
    window.location.href="login.jsp" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow"
   }
}
 </script> 
  
<div class="extra">
     <a class="ui blue right floated primary button" onclick="checkUser()" href="bookConfirm?userId=${account.id}&roomNum=${room.roomNum}&stime=${stime }&etime=${etime }" rel="external nofollow" rel="external nofollow" >确认预订</a>
      </div>

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

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

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

解决方法一

在js函数中加上

1
window.event.returnValue=false

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

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

1
2
3
4
5
6
7
8
9
10
11
12
13
<script type="text/javascript">
  function checkUser()
   if(2!=1){
    window.location.href="login.jsp" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow"
   window.event.returnValue=false;
   }
}
 </script> 
  
<div class="extra">
     <a class="ui blue right floated primary button" onclick="checkUser()" href="bookConfirm?userId=${account.id}&roomNum=${room.roomNum}&stime=${stime }&etime=${etime }" rel="external nofollow" rel="external nofollow" >确认预订</a>
      </div>

解决方法二

点击事件中  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
13
14
15
16
17
18
<script type="text/javascript">
   
  function checkUser()
   if(<%=flag%>!=1){
    window.location.href="login.jsp" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ;
   return false;
   }
}
 </script>
  
 <div class="extra">
     <a class="ui blue right floated primary button" onclick="return checkUser();" 
  
href="bookConfirm?userId=${account.id}&roomNum=${room.roomNum}&stime=${stime }&etime=${etime 
  
}">确认预订</a>
      </div>

解决方法三

如果是form体提交的话还可以把summit改成button调用js提交,这样window.location.href也会在js提交summit之前执行成功跳转。

如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
function checkUser()
   if(<%=flag%>!=1){
    window.location.href="login.jsp" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ;
   return false;
   }
 document.getElementById("form").submit();
}
  
  
  <form action="addRoom" method="post"  name="from" id="form">
      <table align="center" border="1" class="commTable">
        <tr>
          <td class="right"><span
            style="font-weight: blod;">房号:</span></td>
          <td><input type="text" name="roomNum" size="25"
            id="roomNum" /></td>
        </tr>
        <tr>
          <td colspan="2" align="center"><button  value="添加"
            onclick="checkUser()" /></td>
        </tr>
      </table>
    </form>
posted @ 2017-07-07 13:18  chu_叶子  阅读(371)  评论(0)    收藏  举报