问题状况
JS中设置window.location.href跳转无效
缘由是 a标签的href跳转会执行在window.location.href设置的跳转以前:
若是是表单form的话 也会先执行form提交。
提交以后 就已经不在当前页面了。因此 window.location.href无效。
解决方法一
在js函数中加上
window.event.returnValue=false
这个属性放到提交表单中的onclick事件中在此次点击事件不会提交表单,若是放到超连接中则在此次点击事件不执行超连接href属性。
改为以下代码后window.location.href成功跳转:
- <script type="text/javascript">
- function checkUser()
- {
- if(2!=1){
- window.location.href="login.jsp";
- 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 }">确认预订</a>
- </div>
解决方法二
点击事件中 onclick="checkUser()" 变成 onclick="return checkUser();"
而且在 checkUser中 return false;这样的话 a标签的href也不会执行。 这样就能window.location.href顺利跳转。
代码以下:
- <script type="text/javascript">
-
- function checkUser()
- {
- if(<%=flag%>!=1){
- window.location.href="login.jsp";
- 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以前执行成功跳转。
以下:
- function checkUser()
- {
- if(<%=flag%>!=1){
- window.location.href="login.jsp";
- 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>
声明:本文为转载,再次十分百分千分万分感谢博主的分享,谢谢。javascript