Board logo

标题: 遇到问题-----JS中设置window.location.href跳转无效 [打印本页]

作者: look_w    时间: 2019-5-11 13:54     标题: 遇到问题-----JS中设置window.location.href跳转无效

问题情况

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

代码如下:

     <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"  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 class="extra">
              <a class="ui blue right floated primary button"  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 class="extra">
              <a class="ui blue right floated primary button"  
     
    href="bookConfirm?userId=${account.id}&roomNum=${room.roomNum}&stime=${stime }&etime=${etime
    }">确认预订</a>
               </div>




解决方法三

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

如果是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="添加"
                            /></td>
                    </tr>
                </table>
            </form>




欢迎光临 电子技术论坛_中国专业的电子工程师学习交流社区-中电网技术论坛 (http://bbs.eccn.com/) Powered by Discuz! 7.0.0