您的位置:首页 > Web前端 > JavaScript

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

2017-06-21 10:13 393 查看


问题情况

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

代码如下:

[html] view
plain copy

 <script type="text/javascript">  

   function checkUser()  

{   

     if(2!=1){  

        window.location.href="login.jsp";    

     }  

}  

  </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>  

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

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

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


解决方法一

在js函数中加上

window.event.returnValue=false

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

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

[html] view
plain copy

<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顺利跳转。

代码如下:

[html] view
plain copy

 <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>  


解决方法三

感谢qmm0523 在评论中提出这种解法

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

如下:

[html] view
plain copy

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>  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  js window.location.href