• 遇到问题-----JS中设置window.location.href跳转无效(在a标签里或这form表单里)


    问题情况

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

    代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    <script type="text/javascript">
       function checkUser()
    {
         if(2!=1){
            window.location.href="login.jsp"
         }
    }
      </script>
      

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

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

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

    解决方法一

    在js函数中加上

    window.event.returnValue=false

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

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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    <script type="text/javascript">
       function checkUser()
    {
         if(2!=1){
            window.location.href="login.jsp"
         window.event.returnValue=false;
         }
    }
      </script>
      

    解决方法二

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

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

    代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <script type="text/javascript">
       
       function checkUser()
    {
         if(<%=flag%>!=1){
            window.location.href="login.jsp";
         return false;
         }
    }
      </script>
      
  • 相关阅读:
    day15—jQuery UI之widgets插件
    day14—jQuery UI 之dialog部件
    day13—CSS之导航栏
    day12—jQuery ui引入及初体验
    day11—前端学习之我不想看书
    struts2的action方法匹配以及通配符的使用
    Java中的static
    ActiveMQ的简单使用
    MS DOS 常用命令整理
    IntelliJ IDEA 中 Ctrl+Alt+Left/Right 失效
  • 原文地址:https://www.cnblogs.com/everest33Tong/p/5848261.html
Copyright © 2020-2023  润新知