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

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

问题情况

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

代码如下:

<script type="text/javascript"> function checkUser() { if(2!=1){ window.location.href="login.jsp" ; } } </script> <div> <a href="bookConfirm?userId=${account.id}&roomNum=${room.roomNum}&stime=${stime }&etime=${etime }" >确认预订</a> </div>

原因是 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> <a href="bookConfirm?userId=${account.id}&roomNum=${room.roomNum}&stime=${stime }&etime=${etime }" >确认预订</a> </div>

解决方法二

点击事件中   变成

并且在 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> <a 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"> <table> <tr> <td><span>房号:</span></td> <td><input type="text" size="25" /></td> </tr> <tr> <td colspan="2"><button value="添加" /></td> </tr> </table> </form>

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwgjyf.html