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

前端之家收集整理的这篇文章主要介绍了javascript 中设置window.location.href跳转无效问题解决办法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

问题情况

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

代码如下:

nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ; } }

<div class="extra">
确认预订

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

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

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

解决方法

在js函数加上

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

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

nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ; window.event.returnValue=false; } }

<div class="extra">
确认预订

解决方法

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

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

代码如下:

function checkUser()
{
if(<%=flag%>!=1){
window.location.href="login.jsp" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ;
return false;
}
}

<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

}">确认预订

解决方法

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

如下:

!=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;">房号:</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>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持

猜你在找的JavaScript相关文章