javascript 中设置window.location.href跳转无效问题解决办法
问题情况
JS中设置window.location.href跳转无效
代码如下:
<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" rel="external nofollow" rel="external nofollow" >确认预订</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" 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" rel="external nofollow" rel="external nofollow" >确认预订</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" 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">确认预订</a>
</div>
解决方法三
如果是form体提交的话还可以把summit改成button调用js提交,这样window.location.href也会在js提交summit之前执行成功跳转。
如下:
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>
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。