jq的ajax交互封装
jq封装的ajax,然后 在此前和此后都是很多要考虑的 ,何不 想想构思封装下。
下面:
基本上网页都存在各种ajax,使得网页变得更加易于操作。
举个长长的例子吧:
<input type="button" value="↑" onclick="changeBidSign('netcreditadmin/bidSignDownA.action',${bidlists.bidId},'UP')">
这是一个向上的按钮--js方法,
changeBidSign(action,id,status);status存在,使得此方法同样可以运用到 Down Left 之类 下面介绍js,整体构思:

admin:是我写 具体复杂的操作的js方法
ajax——common
ajaxfun:写上简单的ajax提交类似:
/**
* 简单的form表单提交
*/
function simpleSub(formId, callbackFun){
//var DivRef = document.getElementById("Loader");
var options = {
dataType: 'json',
// beforeSubmit: function(){
// //提交开始前使按钮不可用
// $("#"+buttonId).attr("disabled", "true");
// DivRef.style.display = "block";
// },
success: callbackFun //此方法封装在callbackfun.js
};
$("#"+formId).ajaxSubmit(options);
return false;
}
callbackfun.js: 写在response回调函数
进程的分析如下:
前台ajax交互,无非是data不同,要么前面逻辑处理。 所以 分3部分
1. data 和 逻辑处理 写在同一个js里面。
2. ajax基本共用,
3. 回调函数兴许,有时候 div 等局部刷新。所以这里callbackFun 一个远不够。这里归一类。
data 和 逻辑:
function batchDelete(checkboxName, delTagAction, listTagAction, rel){
var ids=new Array();
if($("input[name="+checkboxName+"]:checked").size()==0){
alertMsg.warn("请至少选择一条需要删除的数据!");
return false;
}
$("input[name="+checkboxName+"]:checked").each(function(i,obj){
ids[i]=$(obj).val();
});
var idStr=ids.join("-");
//alert(idStr);
if (confirm("删除的数据将放入回收站,确定继续")) {
dialogAjaxSimple(delTagAction,idStr);
}else{ return false;
}
}
ajax基本共用:
function dialogAjaxSimple(tagAction,idStr){
$.ajax({
url:tagAction,
data:{
sendTime:(new Date()).getTime(),
idStr:idStr
},
type:"post",
async:false,
dataType:"json",
success:reponse
});
}
回调函数兴许,有时候 div 等局部刷新:
//tab页面的ajax回调
function response(data){
if(data.success == true){
alertMsg.correct(data.msg);
var $box = $("#"+data.rel+"");
$box.ajaxUrl({
type:"POST", url:data.url, data: null, callback:function(){
$box.find("[layoutH]").layoutH();
}
});
}else{
alertMsg.error(data.reason);
}
}
在后台,我想说的也有:
两个文件,一个是类,一个是reponse后的页面。
类先说吧:
clientResponse = successResponse("操作成功",
"netcreditadmin/getbidListA.action", "bidId");
这个是我 getset的字符串clientResponse。
···/**
* ajax返回的json对象
* */
protected String failResponse(String reason) {
String response = "{\"success\": false, \"reason\":\"" + reason + "\"}";
return response;
} protected String successResponse(String msg, String url, String rel) {
String response = "{\"success\": true,\"msg\":\"" + msg
+ "\",\"url\":\"" + url + "\",\"rel\":\"" + rel + "\"}";
return response;
}
先看配置文件吧:
<action name="bidSignDownA" class="xidian.sl.netcredit.action.admin.BasicDataA"
method="bidSignDownA_">
<result name="success">/WEB-INF/ajax_response/client.jsp</result>
</action>
ajax_response/client.jsp:
<%@ taglib prefix="s" uri="/struts-tags"%>
<% response.setCharacterEncoding("UTF-8"); %>
<% System.out.println(response);%>
<s:property value="clientResponse" escape="false"/>
到这里终于 全部过程讲了一遍。适合学过jq的人。
这封装不单单这一种,但是我想说,这慢慢改 慢慢改都会可以的。java之路皆美也,共同开发。
学jq,js 学java 必须带这脑子学。做这个必须让自己,问自己为什么做这个。
加油!!!
jq的ajax交互封装的更多相关文章
- JQ中的Ajax的封装
1.认识JQ中ajax的封装 jQ 对于ajax的封装有两层实现:$.ajax 为底层封装实现:基于 $.ajax ,分别实现了$.get 与$.post 的高层封装实现: 2.Ajax的底 ...
- ajax的封装——jq简化版
最近在复习ajax的知识,练习了下ajax的封装,此处做下笔记 废话不多说,直接代码 //发请求 //此处的url为请求地址,type为请求方式,success为请求成功的回调函数 myaxios({ ...
- 原生态AJAX详解和jquery对AJAX的封装
AJAX: A :Asynchronous [eI`sinkrenes] 异步 J :JavaScript JavaScript脚本语言 A: And X :XML 可扩展标记语言 AJAX现在 ...
- 关于jQ的Ajax操作
jQ的Ajax操作 什么是AJAX AJAX = 异步的javascript和XML(Asynchronous Javascript and XML) 它不是一门编程语言,而是利用JavaScript ...
- jQuery-实现简单的Ajax请求封装
封装的意义在于复用,在于减少重复的代码. 我在项目中做了简单的Ajax请求封装,实现方式如下: //封装Ajax请求 $.extend({ ajaxDirect:function(url,type,d ...
- jq的ajax方法
相较与js异步对象的繁琐,jq的ajax对象结构更加清晰 一:ajax对象简述 ajax(Asynchronous JavaScript and XML),异步的xml和js对象,主要用于在不刷新全局 ...
- ThinkPHP中使用ajaxReturn进行ajax交互
以管理员登录为例来介绍下$this->ajaxReturn与模板页进行ajax交互使用方法 首先看PHP控制器的处理,在application/Admin/Controller/LoginCon ...
- struts2 的验证框架validation如何返回json数据 以方便ajax交互
struts2 的验证框架validation简单,好用,但是input只能输出到jsp页面通过struts2的标签<s:fielderror />才能取出,(EL应该也可以). 如果使 ...
- struts2中使用json插件实现ajax交互
json插件可以简单的实现ajax交互,避免了使用struts2-dojo-plugin.jar包时带来的struts2.x版本冲突问题.并且减少了使用ajax标签时需要的繁琐的配置包括web.xml ...
随机推荐
- 探索未知种族之osg类生物---呼吸分解之渲染遍历一
总结 前面我们基本上已经完成对ViewerBase::frame()函数的探究,只剩下renderingTraversals()渲染遍历的探究,虽然就剩下了一个函数,但是这却是最重要的,不可少的一个步 ...
- python04 列表 元祖 字典
1.list 有序,元素可以被修改 li=[1,2,2,"am","123"] 列表中的元素可以是数字,字符串,列表等等 支持切片,切片结果为列表 li[3] ...
- python_day12_css
目录: 简介 选择器(selecttor) 常用属性 页面布局 一.简介 1.CSS 定义 CSS是Cascading Style Sheets的简称,中文称为层叠样式表. CSS 规则由两个主要的部 ...
- ----一个roadmap----
在课上了解到了学web前端三个基础,HTML.CSS.JS 从HTML开始,逐步学习CSS.JS 大致写了一个roadmap(应该是roadmap喔 就是这样,以后可能会来更错或者更新 对没错我来更错 ...
- Maven学习 三 Maven与Eclipse结合使用
一检查是否已经集成了Maven 现在的Eclipse一般都是集成了Maven,如果确定集成开发工具是否集成了Maven, Windows->preferences->Maven,查看是否已 ...
- 数据库-mysql语句-查-WEB服务器
(1)MySQL中的查询 (2)WEB服务器 Order: 订单.排序 Set:设置.集合 Table:表.桌子 1.MySQL中的简单查询 —— 查询结果的排序 示例:查询出所有员工信息,要求按工 ...
- TensorFlow 运行模型--会话(Session)
会话模式一: 需要明确调用会话生成函数和关闭函数 # 创建一个会话 sess = tf.Session() # 使用创建好的会话进行运算 sess.run("要运算的对象") # ...
- bootstrap的化妆页面
Glyphicons 字体图标 所有可用的图标 包括260个来自 Glyphicon Halflings 的字体图标.Glyphi cons Halflings 一般是收费的,但是他们的作者允许 Bo ...
- WeexSDK源码分析(iOS)
0.从工作原理谈起 Weex 表面上是一个客户端技术,但实际上它串联起了从本地开发.云端部署到分发的整个链路.开发者首先可在本地像编写 web 页面一样编写一个 app 的界面,然后通过命令行工具将之 ...
- 使用 Resharper 快速做适配器
如果需要做一个类的重写,需要重新写这个类的所有属性和函数,本文提供一个简单的方法让大家快速重写一个类的所有属性和函数. 在有 Resharper 之后,对一个比较长的类进行重构.例如有这个类 clas ...