javascript 中设置window.location.href跳转无效问题解决办法


Posted in Javascript onFebruary 09, 2017

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?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" 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?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" 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?userId=${account.id}&roomNum=${room.roomNum}&stime=${stime }&etime=${etime  
 
}">确认预订</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>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
javascript 写类方式之十
Jul 05 Javascript
一个关于javascript匿名函数的问题分析
Mar 30 Javascript
JavaScript输入邮箱自动提示实例代码
Jan 13 Javascript
JavaScript的ExtJS框架中数面板TreePanel的使用实例解析
May 21 Javascript
Vue.js双向绑定实现原理详解
Dec 22 Javascript
Angular指令封装jQuery日期时间插件datetimepicker实现双向绑定示例
Jan 22 Javascript
浅谈vue项目优化之页面的按需加载(vue+webpack)
Dec 11 Javascript
Vue-Router模式和钩子的用法
Feb 28 Javascript
微信小程序实现弹出菜单功能
Jun 12 Javascript
JavaScript实现构造json数组的方法分析
Aug 17 Javascript
Vue路由模块化配置的完整步骤
Aug 14 Javascript
vue.js中使用微信扫一扫解决invalid signature问题(完美解决)
Apr 11 Javascript
微信小程序之picker日期和时间选择器
Feb 09 #Javascript
BootStrap 弹出层代码
Feb 09 #Javascript
jQuery插件form-validation-engine正则表达式操作示例
Feb 09 #Javascript
javascript history对象详解
Feb 09 #Javascript
jquery dialog获取焦点的方法
Feb 09 #Javascript
jQuery实现淡入淡出的模态框
Feb 09 #Javascript
Base64(二进制)图片编码解析及在各种浏览器的兼容性处理
Feb 09 #Javascript
You might like
用PHP写的MySQL数据库用户认证系统代码
2007/03/22 PHP
php快速查找数据库中恶意代码的方法
2015/04/01 PHP
PHP将页面中点击数量高的链接进行高亮显示的方法
2016/05/30 PHP
浅谈PHP中try{}catch{}的使用方法
2016/12/09 PHP
PHP递归实现汉诺塔问题的方法示例
2017/11/25 PHP
用js得到网页中所有的div的id
2020/10/19 Javascript
从零开始学习jQuery (十一) 实战表单验证与自动完成提示插件
2011/02/23 Javascript
JavaScript省市联动实现代码
2014/02/15 Javascript
有关JavaScript中call()和apply() 的一些理解
2016/05/20 Javascript
BootStrap Table 获取同行不同列元素的方法
2016/12/19 Javascript
Node.js常用工具之util模块
2017/03/09 Javascript
AngularJS中使用ngModal模态框实例
2017/05/27 Javascript
手把手搭建安装基于windows的Vue.js运行环境
2017/06/12 Javascript
微信小程序中使用Async-await方法异步请求变为同步请求方法
2019/03/28 Javascript
bootstrap tooltips在 angularJS中的使用方法
2019/04/10 Javascript
JavaScript获取某一天所在的星期
2019/09/05 Javascript
JS实现百度搜索框
2021/02/25 Javascript
python登陆asp网站页面的实现代码
2015/01/14 Python
python BeautifulSoup设置页面编码的方法
2015/04/03 Python
用Python的SimPy库简化复杂的编程模型的介绍
2015/04/13 Python
一个Python最简单的接口自动化框架
2018/01/02 Python
Python读取mat文件,并保存为pickle格式的方法
2018/10/23 Python
python 从文件夹抽取图片另存的方法
2018/12/04 Python
python过滤中英文标点符号的实例代码
2019/07/15 Python
python shutil文件操作工具使用实例分析
2019/12/25 Python
英国时尚运动品牌的合集:The Sports Edit
2017/12/20 全球购物
德国滑雪和户外用品网上商店:XSPO
2019/10/30 全球购物
教育科学研究生自荐信
2013/10/09 职场文书
高校学生干部的自我评价分享
2013/11/04 职场文书
优秀员工自荐书范文
2013/12/08 职场文书
经济管理毕业生求职信
2014/03/15 职场文书
群众路线领导班子四风对照检查材料
2014/09/27 职场文书
子女赡养老人协议书
2016/03/23 职场文书
七年级之开学家长寄语35句
2019/09/05 职场文书
三年级作文之小小梦想
2019/12/06 职场文书
Python图像处理之图像拼接
2021/04/28 Python