ajax回调中的this.href不执行跳转的解决办法

1. 问题背景

如下所示代码:

复制代码
        $.post("/ems/register",indata, function(data){
            if(data != null && data.result == 'error'){
                $("#no_error").text(data.msg);
                return false;
            }else{
                this.href="/ems/registerSuccess";
            }
        },'json');

即使注册成功, data.result != 'error' ,代码 : this.href="/ems/registerSuccess"; 也不会执行。测试了很久,最后才怀疑到ajax异步上来。

原因就是这里是异步调用,this.href 是处在异步调用的回调中。

但是即使是我们使用了ajax的同步调用,那么在回调函数中的:this.href="/ems/registerSuccess"; 也不会执行:

复制代码
        $.ajax({
            url:"/ems/register",
            async:false, // 注意此处需要同步,不然后面的 this.href=xxx 不执行
            type:"POST",
            dataType:"json",
            data:indata,
            success:function(data) {
                if(data != null && data.result == 'error'){
                    alert(222);
                    $("#no_error").text(data.msg);
                    return false;
                }else{
                    // 这里的this.href不会执行
                    this.href="/ems/registerSuccess";
                }
            }
        });

即使我们 async:false 采用同步调用,在firefox浏览器中的,回调函数中的 this.href="/ems/registerSuccess"; 也不会执行。

**2.**解决方法一

只有采用同步的同时,在 ajax 代码后面的 this.href="/ems/registerSuccess"; 才会执行。

复制代码
        $.ajax({
            url:"/ems/register",
            async:false, // 注意此处需要同步,不然后面的 this.href=xxx 不执行
            type:"POST",
            dataType:"json",
            data:indata,
            success:function(data) {
                if(data != null && data.result == 'error'){
                    alert(222);
                    $("#no_error").text(data.msg);
                    return false;
                }else{
                    // 这里的this.href不会执行
                    //this.href="/ems/registerSuccess";
                }
            }
        });
        this.href="/ems/registerSuccess";

最后面的 this.href="/ems/registerSuccess"; 在ajax 同步调用的后面,才会执行。

3. 解决方法二

既然我们不能使用 this.href, 那么我们可以换一种方式,我们使用 window.open(url,'_self'),经过测试,不存在this.href的问题。代码如下:

复制代码
        $.post("/ems/register",indata, function(data){
            if(data != null && data.result == 'error'){
                $("#no_error").text(data.msg);
                return false;
            }else{
                //this.href="/ems/registerSuccess";
                window.open("/ems/registerSuccess", '_self');
            }
        },'json');

这也算是 window.href 和 window.open(url,'_self')的一个小区别吧。

4. 解决方法三

我们在服务端 重定向,不在浏览器端重定向。就可以绕开这个问题。(其实服务端 重定向也是不行的,因为是一个 ajax 的请求,所以服务端的重定向不起任何作用,它不会让页面重定向到新的页面。)

相关推荐
林深现海24 分钟前
Jetson Orin nano/nx刷机后无法打开chrome/firefox浏览器
前端·chrome·firefox
黄诂多38 分钟前
APP原生与H5互调Bridge技术原理及基础使用
前端
前端市界41 分钟前
用 React 手搓一个 3D 翻页书籍组件,呼吸海浪式翻页,交互体验带感!
前端·架构·github
文艺理科生42 分钟前
Nginx 路径映射深度解析:从本地开发到生产交付的底层哲学
前端·后端·架构
千寻girling43 分钟前
主管:”人家 Node 框架都用 Nest.js 了 , 你怎么还在用 Express ?“
前端·后端·面试
C澒1 小时前
Vue 项目渐进式迁移 React:组件库接入与跨框架协同技术方案
前端·vue.js·react.js·架构·系统架构
清山博客1 小时前
OpenCV 人脸识别和比对工具
前端·webpack·node.js
要加油哦~1 小时前
AI | 实践教程 - ScreenCoder | 多agents前端代码生成
前端·javascript·人工智能
程序员Sunday2 小时前
说点不一样的。GPT-5.3 与 Claude Opus 4.6 同时炸场,前端变天了?
前端·gpt·状态模式
yq1982043011562 小时前
静思书屋:基于Java Web技术栈构建高性能图书信息平台实践
java·开发语言·前端