art.dialog 与 ajax 异步请求
上周写了一些代码,涉及到jquery异步请求,这里归纳总结下,希望对刚接触编程的同学有帮助。
主要习惯使用 art.dialog 框架,非常好用,在异步请求上,它提供了很多简便的方法。
加载使用art.dialog前,需要在页面代码上引入
<link href="/js/artDialog/css/blue.css" type="text/css" rel="stylesheet" /> <script type="text/javascript" charset="utf-8" src="/js/artDialog/artDialog.js?skin=default"></script>
在jquery1.9.1版本或以上,不支持live()事件,用
$(document).on("click","td #id",function(){
})
替代live事件,响应动态显示的标签。
获得需要的数据:
ajax异步请求前,需要获取参数的值。主要有两种方式可以获得页面传过来的值。
不管是响应button <a> 还是其他,需要在相应标签内添加传来的参数值,如:
<a id="ajaxQuery" name="xxx" age="18" >ajaxquery</a>
它的响应事件获得参数方法:
$(document).on("click", "#ajaxQuery" , function(){
var name = $(this).attr('name');
var age = $(this).attr('age'); //这两种方式是通过获取属性值实现
var value = $(this).val(); //通过获取该标签的value值来实现
})
由于ajax请求一般是异步请求,所以在执行.get类的方法后,这类方法的数据是无法再传给后面的函数调用。
弹框显示:
一般调用art.dialog的基本步骤:
art.dialog(){
lock: true, //屏锁
background:'#333333', //背景色
opacity: 0.6, //透明度
title: '标题',
id: '',
content: '' //弹框html脚本。
ok:function() {
}
}
在ok : function() {}中写ajax请求脚本,
$.getJSON('url',function( data ) {
//url为请求的url,可直接在url后面接参数和值,传参过去
});
或者
$.getJSON( 'URL' ,data,function(data) {
})
data为传递参数。
请求完成后,依据返回来的参数判断是否响应成功,若成功,可返回指定页面
if ( data.code = 'true' ) {
window.location.href = 'url';
}
基本上使用art.dialog整个流程到这里就结束了,接下来,具体谈下这几种ajax请求,和多选项时提交的情况。
多项选,selected情况的多选项情况:
var valueArr = [];
$("#id option:selected").each(function(){
var value = $(this).val();
valueArr.push( value );
}
checked多选项时情况:
var valueArr = [];
$("#id td .checked").each( function() {
var value = $(this).val();
valueArr.push( value );
}
ajax请求方法:
$.post("url",{'data':valueArr,'data2': value} ,function( data ) {
},json);
应对form表单的提交,这里有一个更优的方法:
var FormValue = $("#FormId").serialize();
$.get ( "url",FormValue,function(data){
data = eval("(" + data + ")"); //json decode
if(data.code === 1001 ) {
window.location.href = '/url';
}
else {
return false;
}
});
其他ajax当然还有 $.ajax $.getAjax等,也可以直接 用jquery 的submit事件实现表单提交。
art.dialog 与 ajax 异步请求的更多相关文章
- ajax异步请求
做前端开发的朋友对于ajax异步更新一定印象深刻,作为刚入坑的小白,今天就和大家一起聊聊关于ajax异步请求的那点事.既然是ajax就少不了jQuery的知识,推荐大家访问www.w3school.c ...
- spring HandlerInterceptorAdapter拦截ajax异步请求,报错ERR_INCOMPLETE_CHUNKED_ENCODING
话不多说,直接上正文. 异常信息: Failed to load resource: net::ERR_INCOMPLETE_CHUNKED_ENCODING 问题描述: 该异常是在页面发送ajax请 ...
- jquery Ajax异步请求之session
写了一个脚本,如下: $(function () { $("#btnVcode").click(function () { var receiveMobile = $(" ...
- ajax异步请求Response.Redirect重定向
一个ajax异步请求报错->捕获异常->重定向错误提示页面. 一个简单的流程 结果一直搞不定.重定向无效.各种百度之. 后来突然想起 ajax的请求是不能在后台重定向的. 如果硬要重定向 ...
- jquery的ajax异步请求接收返回json数据
http://www.jb51.net/article/51122.htm jquery的ajax异步请求接收返回json数据方法设置简单,一个是服务器处理程序是返回json数据,另一种就是ajax发 ...
- MVC&WebForm对照学习:ajax异步请求
写在前面:由于工作需要,本人刚接触asp.net mvc,虽然webform的项目干过几个.但是也不是很精通.抛开asp.net webform和asp.net mvc的各自优劣和诸多差异先不说.我认 ...
- AJAX异步请求原理和过程
AJAX 指异步 JavaScript 及 XML(Asynchronous JavaScript And XML),它不是一种新的编程语言,而是一种使用现有标准的新方法. AJAX 基于 JavaS ...
- Ajax异步请求-简单模版
<script type="text/javascript"> window.onload = function () { document.getElementByI ...
- ajax异步请求不能刷新数据的问题
搞了两三天的问题,今天解决了.总结下: function reportGrpChange(cuid, title){ document.getElementById('reportFrameDiv') ...
随机推荐
- Maven管理项目架包
最近一直在用Maven管理项目的架包,从而发现了几个不错的官方或者非官方的网站. http://mvnrepository.com/artifact/com.ning 这个是我刚刚用来找HTTP开发 ...
- 最火的Android开源项目(完结篇)
65. AndroidSideMenu AndroidSideMenu能够让你轻而易举地创建侧滑菜单.需要注意的是,该项目自身并不提供任何创建菜单的工具,因此,开发者可以自由创建内部菜单. 66. A ...
- [Javascript] Create an Array concatAll method
In addition to flat Arrays, programmers must often deal with nested Arrays. For example let's say we ...
- 图解如何用U盘重装系统
第一类方法: 原生U盘安装,本工具制作完的U盘启动菜单含Windows7操作系统安装功能,使用本功能可以将Win7系统完美移植到你的U盘中.本功能不用进PE不用虚拟光驱,不受FAT32和NTFS文件系 ...
- c#进程间通讯方案之IPC通道
转载:http://www.cnphp.info/csharp-ipc-channel-remoting.html 最近一直纠结与使用多进程还是多线程来构建程序.多线程的方法似乎不错,但是一个进程可承 ...
- Unity 3D 文件导入出错误解决方法以及unity圣典离线版下载地址
1.安装unity 时我选择了free版的,打开已有项目时出现如下错误提示. 解决方法:先把要导入的文件先拷贝到unity3d安装目录下对应的文件夹内,之后再返回unity3d软件,右键选择“导入”. ...
- Android开发之Adapter
学习android时,对于我这种初学者来说,刚开始接触控件,发现有的控件需要adapter有些不需要,对此我感到不解.所以决定一探究竟. 其实android是一个完全遵从MVC模式的框架,activi ...
- ADB操作多台设备
1.adb devices 查看所有连接设备. 2.adb -s <设备名> shell 指定device来执行adb shell. 3.adb -s <设备名> <指令 ...
- Android出现Read-only file system 解决方法
操作AVD文件系统上的文件时遇到"... Read-only file system". 解决办法: 将AVD sdcard挂载为读写权限: 在doc下执行:adb -s emul ...
- leetcode342——Power of Four(C++)
Given an integer (signed 32 bits), write a function to check whether it is a power of 4. Example:Giv ...