1.在发送ajax请求一般都是默认为异步,就是不去等待后台响应直接可以继续发送,

但这样会有时候遇到一些问题,无法获得后台的响应参数,

所以在你打开编辑弹出框完成数据编辑后无法刷新页面,

这时候可能存在的问是

(1)跨域

(2)网络延迟未获取响应数据

(3)加载的仍然是缓存中的数据,无法刷新

(4)浏览器插件拦截

解决问题思路:

跨域:

可以使用后台解决或者前台解决解决方式不细说百度下

网络延迟未获取到响应数据:

可以在ajax中将异步请求修改为同步(操作看以下示例)

缓存问题:

可以清除本地浏览器缓存

浏览器插件:

将可翻墙的或者安装的浏览器插件关闭

工作中遇到的示例(折磨好久):

1.实现的功能

使用layui将展示的数据进行审核

点击待审核:

备注审核的内容手动审核通过还是未通过

修改状态后的效果

前端思路:

首先编写一个layui的点击按钮,但layui需要在展示栏中引入一个参数

这是layui的一个初始化列表:

-----examine.js文件中的初始化列表-----

/**
* 初始化表格的列
*/
Examine.initColumn = function () {
return [[
{type: 'checkbox'},
{field: 'accountid', hide: true, sort: true, title: '商户id'},
{field: 'acname', sort: true, title: '商户名称'},
{field: 'type', hide:true, sort: true, title: '审核类型'},
{field: 'baltype', sort: true, title: '审核类型'},
{field: 'money', sort: true, title: '金额'},
{field: 'actualmoney', sort: true, title: '实际提现'},
{field: 'commission', sort: true, title: '手续费'},
{field: 'beforechange', sort: true, title: '变动前金额'},
{field: 'afterchange', sort: true, title: '变动后余额'},
{field: 'createtime', sort: true, title: '提交时间'},
{field: 'updatetime', sort: true, title: '更新时间'},
{field: 'status', hide:true, sort: true, title: '审核状态'},
{field: 'dicstatus', sort: true, title: '审核状态'},
{field: 'receivabletype',hide:true, sort: true, title: '收款方式'},
{field: 'receiv', sort: true, title: '收款方式'},
{field: 'remark', sort: true, title: '备注'},
{toolbar: '#tableBar', title: '审核', minWidth: },
]];
};
//最后一行为点击待审核的一个按钮,先查出指定的数据并将数据放入域中跳转页面;

-----java后台跳转的页面-----

*
* @author xl
* @Date // : PM
*/
@RequestMapping("/examine_update/{id}")
public String accountUpdate(@PathVariable String id, Model model) {

if (ToolUtil.isEmpty(id)) {
throw new RequestEmptyException();
}
//缓存部门修改前详细信息
AcBalanceChange acBalanceChange = acBalanceChangeService.selectByPrimaryKey(Integer.parseInt(id));
model.addAllAttributes(BeanUtil.beanToMap(acBalanceChange));
LogObjectHolder.me().set(acBalanceChange);
return PREFIX + "examine_edit.html";
}

-------examine.html主页面-------

//js是根据id关联的
<script type="text/html" id="tableBar">
// 这个script 是layui的判断要显示的按钮,根据后台的状态值去判断的
{{# if(d.status == ''){ }}
<a class="layui-btn layui-btn-primary layui-btn-xs" lay-event="edit">待审核...</a>
{{# } else if(d.status == ''){ }}
<a class="layui-btn layui-btn-primary layui-btn-xs" style="background: lightgreen">审核通过</a>
{{# } else if(d.status == ''){ }}
<a class="layui-btn layui-btn-primary layui-btn-xs" style="background: #CD808C">审核未通过</a>
{{# } }}
</script>

--------examine_edit.html文件--------

@layout("/common/_container.html",{bg:"bg-white",js:["/assets/modular/system/examine/examine_edit.js"]}){
<form id="examineForm" lay-filter="examineForm" class="layui-form model-form">
<input name="id" id="bcid" value="${id}" placeholder="" type="hidden" class="layui-input" lay-verify="required" required/>

<div class="layui-form-item">
<label class="layui-form-label">备注<span style="color: red;">*</span></label>
<div class="layui-input-block">
<input id="remark" name="remark" placeholder="备注" type="text" class="layui-input" lay-verify="required" required/>
</div>
</div>

<div class="layui-form-item text-right">
<button class="layui-btn layui-btn-primary" type="button" ew-event="closeDialog">取消</button>
<button class="layui-btn" id="adopt" lay-submit>通过</button>
<button class="layui-btn" id="notadopt" lay-submit>未通过</button>
</div>
</form>
@}

------examine_edit.js文件------

//此时我要绑定两个ajax请求来修改编辑的内容
layui.use(['layer', 'form', 'admin', 'ax'], function () {
var $ = layui.jquery;
var $ax = layui.ax;
var form = layui.form;
var admin = layui.admin;
var layer = layui.layer;

// 让当前iframe弹层高度适应
admin.iframeAuto();

$("#adopt").click(function (data) {
//选中对象的id
var id = $("#bcid").val();
var remark = $("#remark").val();
console.log(remark)
$.ajax({
url: Feng.ctxPath + "/examine/update",
data: {'id': id, 'status': '', 'remark': remark},
type: "Post",
async: false,//关闭异步请求
dataType: "json",
//传给上个页面,刷新table用
success: function (data) {
console.log(data + "========")
Feng.success("审核成功!");
admin.putTempData('formOk', true);
// window.parent.location.reload();
//关掉对话框
admin.closeThisDialog();
},
error: function (data) {
$.messager.alert('错误', data.msg);
}
});
});

$("#notadopt").click(function (data) {
//选中对象的id
var id = $("#bcid").val();
var remark = $("#remark").val();
console.log(remark)
$.ajax({
url: Feng.ctxPath + "/examine/update",
data: {'id': id, 'status': '', 'remark': remark},
type: "Post",
async: false,//关闭异步请求
dataType: "json",
success: function (data) {
console.log(data + "========")
Feng.success("审核成功!");
//传给上个页面,刷新table用
// window.parent.location.reload();
admin.putTempData('formOk', true);
//关掉对话框
admin.closeThisDialog();
},
error: function (data) {
$.messager.alert('错误', data.msg);
}
});
});
});

关注秦川以北会有更多精彩!!!

发送ajax请求时候注意的问题的更多相关文章

  1. 在发送ajax请求时加时间戳或者随机数去除js缓存

    在发送ajax请求的时候,为了保证每次的都与服务器交互,就要传递一个参数每次都不一样,这里就用了时间戳 大家在系统开发中都可能会在js中用到ajax或者dwr,因为IE的缓存,使得我们在填入相同的值的 ...

  2. 原生js发送ajax请求

    堕落了一阵子了,今天打开博客,发现连登录的用户名和密码都不记得了.2016年已过半,不能再这么晃荡下去了. 参加了网易微专业-前端攻城狮 培训,目前进行到大作业开发阶段,感觉举步维艰.但是无论如何,不 ...

  3. jQuery发送ajax请求

    利用jquery发送ajax请求的几个模板代码. $.ajax({ async : false, type: 'POST', dataType : "json", url: &qu ...

  4. JQuery发送ajax请求不能用数组作为参数

    JQuery发送ajax请求不能用数组作为参数,否则会接收不到参数, 一.js代码如下: $('#delete-button').click(function(){        var select ...

  5. js中使用队列发送ajax请求

    最近,项目中需要按照先后顺序发送ajax请求,并且在一次请求结束后才能发起下一次,不然就会导致逻辑错误. 解决办法是定义一个数组,保存ajax请求数据. 以下使用extjs4定义一个类 Ext.def ...

  6. IE6下a标签上发送ajax请求总是error

    IE6下真是处处是坑啊!!!走过了一个又一个坑,记录一下吧. 之前不知道a标签上注册click事件之后,发送ajax请求总是error.后来经过几番网上搜索,终于找到高人遇到此坑的解决办法.原来是a标 ...

  7. Jquery发送ajax请求以及datatype参数为text/JSON方式

    Jquery发送ajax请求以及datatype参数为text/JSON方式 1.方式一:datatype:'text' 2.方式二:datatype:'JSON' 3.使用gson-1.5.jar包 ...

  8. 【liferay】1、使用alloy-UI发送ajax请求

    1.首先liferay要发送ajax请求,那么就需要在jsp中定义resourceURL <portlet:resourceURL var="workDeal" id=&qu ...

  9. Axios发送AJAX请求

    目录 Axios 特征 axios提供主要三种发起请求的方式 方式一:直接axios实例直接call方式 方式二:通过axios实例提供的不同http请求方式的方法 方式三:其实是从第二种方式中单独提 ...

  10. 接入天猫精灵auth2授权页面https发送ajax请求

    已存在一个应用A,采用的是http交互, 在接入天猫精灵时,要求请求类型是https,所以在应用服务前加了个nginx转发https请求.在绑定授权页面,会发送ajax请求验证用户名和密码,采用htt ...

随机推荐

  1. 「疫期集训day9」七月

    我们暂时被击退了,可恶的德国佬----我们集结了英国人,意大利人,荷兰人,澳大利亚人,来自世界各地,我们万众一心,还能失守亚眠?----亚眠中坚守的协约国士兵 日常考爆,T1貌似全场就我傻乎乎的推式子 ...

  2. 状压DP之集合选数

    题目 [HNOI2012]集合选数 <集合论与图论>这门课程有一道作业题,要求同学们求出{1, 2, 3, 4, 5}的所有满足以 下条件的子集:若 x 在该子集中,则 2x 和 3x 不 ...

  3. 蓝桥杯大学B组省赛2020模拟赛(一)题解与总结

    题目链接:https://www.jisuanke.com/contest/6516 A:题目: 我们称一个数是质数,而且数位中出现了 5 的数字是有趣的. 例如 5, 59, 457.求1到1000 ...

  4. JS的数据类型你真的懂了吗

    一.JS数据类型分类 1.基本数据类型 (1)Number 数字 (2)String 字符串 (3)Boolean 布尔值 (4)null 空对象指针 (5)undefined 为定义 (6)symb ...

  5. bugku extract 变量覆盖

  6. Java 字符串比较、拼接问题

    @ 目录 1.字符串的比较 1. 1 字符串常量池 1.2 String类型的比较方式 1.3 String的创建方式 1.3.1 直接使用"="进行赋值 1.3.2 使用&quo ...

  7. 数据可视化之powerBI技巧(二十)采悟:创建度量值,轻松进行分组统计

    上一篇文章中的分组,都是通过新建列的方式实现的,直观上比较容易理解.不过这样都修改了原始数据的结构,如果我们不在源表上进行修改,直接通过度量值的方式来进行分组,是否可以实现呢? 答案当然是肯定的. 采 ...

  8. Python面向对象04 /封装、多态、鸭子类型、类的约束、super

    Python面向对象04 /封装.多态.鸭子类型.类的约束.super 目录 Python面向对象04 /封装.多态.鸭子类型.类的约束.super 1. 封装 2. 多态 3. 鸭子类型 4. 类的 ...

  9. Zabbix 4.0 API 实践,主机/主机群组 批量添加模板和删除模板

    场景 我们日常在管理Zabbix 的时候,经常会需要批量添加模板和批量删除模板,Zabbix页面是提供的批量链接的功能,但是它链接的也只是当前页的主机,我们想扩展这个功能,在链接的时候,可以批量链接整 ...

  10. 五大高效的PDF文件搜索引擎

    当你花了半个多小时在线搜索PDF文档,却发现您找到的文档都不是您需要的PDF格式.如前说述,您可以先打开PDF文档查看是不是PDF格式的,然后再到web浏览器中下载该文档.那么,为了确保您获得的文档是 ...