zoukankan      html  css  js  c++  java
  • 解决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" onclick="checkUser()" href="bookConfirm?userId=${account.id}&roomNum=${room.roomNum}&stime=${stime }&etime=${etime }" 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";  
         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 }" 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"; 
          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>

    资源搜索网站大全 https://www.renrenfan.com.cn 广州VI设计公司https://www.houdianzi.com

    解决方法三

    如果是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="添加"
                onclick="checkUser()" /></td> 
            </tr> 
          </table> 
        </form>
  • 相关阅读:
    Codeforces Round #613 选讲
    Codeforces Round #612 选讲
    Codeforces917E
    一道题20
    LOJ#2244. 「NOI2014」起床困难综合症
    求欧拉回路
    *LOJ#2134. 「NOI2015」小园丁与老司机
    vim操作命令
    常见问题解决
    CentOS7下如何修改mysql的数据目录
  • 原文地址:https://www.cnblogs.com/xiaonian8/p/14085565.html
Copyright © 2011-2022 走看看