---恢复内容开始---

jQuery与Ajax的应用

【Ajax的优势和不足】

优势

(1)不需要插件支持;

(2)优秀的用户体验;

(3)提高Web程序的性能;

(4)减轻服务器和宽带的负担;

不足

(1)浏览器对XMLHttpRequest对象的支持度不足;

(2)破坏浏览器前进、“后退”按钮的正常功能;

(3)对搜索引擎的支持的不足;

(4)开发和调试工具的缺乏;

【Ajax的XMLHttpRequest对象】

它是Ajax实现的关键——发送异步请求、接收响应及执行回调都是通过它来完成。

安装Web环境——AppServ

【jQuery中的Ajax】

load()方法:能载入远程HTML代码并插入DOM中。结构为:load( url [,data] [,callback])

参数解释:url:string类型,请求HTML页面的URL地址;

     data(可选):object类型,发送至服务器的key/value数据;

     callback(可选):function类型,请求完成时的回调函数,无论请求成功或失败。

载入HTML文档:开发人员只需要使用jQuery选择器为HTML片段指定目标位置,然后将要加载的文件的URL作为参数传给load()方法即可。主页面的样式会立即应用到新加载的内容上。

筛选载入的HTML文档:load()方法的URL参数的语法结构为:"url selector"。如:$("#resText").load("test.html .para");

传递方法:根据参数data来自动指定。如果没有参数传递,则采用GET方式传递;反之,则会自动转换成POST方式。

//无参数传递,即GET方式
$("resText").load("test.php",function(){
//....
});
//有参数传递,即POST方式
$("resText").load("test.php",{name:"rain",age:"22"}.function(){
//....
});

回调参数:对于必须在加载完成后才能继续的操作,load()方法提供了回调函数(callback),该函数有三个参数,分别代表请求返回的内容、请求状态和XTMLHttpRequest对象

$("resText").load("test.html",function(responseText textStatus XMLHttpRequest){
//responseText:请求返回的内容
//textStatus:请求状态:success、error、notmodified、timeout四种
//XMLHttpRequest:XMLHttpRequest对象
)};

在load()方法中,无论Ajax请求是否成功,只要当请求完成后,回调函数就会被触发。

$.get()方法和$.post()方法

这两个方法是jQuery中的全局函数。可以传递一些参数给服务器中的页面。

$.get()方法:使用GET方法来进行异步请求。结构为:$.get(url [,data] [,callback] [,type])

data(可选):object类型,发送至服务器的key/value数据会作为QueryString附加请求到URL中。

callback(可选):function类型,载入成功时回调函数(只有当Response的返回状态是success才调用该方法)自动将请求结果和状态传递给该方法。

type(可选):string类型,服务器端返回内容的格式,包括xml、html、script、json、text和_default。

(1)使用参数

$("#send").click(function(){
$.get("get1.php",{
username:$("#username").val(),
content:$("#content").val()
},回调函数);
});

$.get()方法的回调函数只有两个参数,且只有当数据成功返回后才会被调用。代码如下

function(data,textStatus){
//data: 返回的内容,可以是XML文档、JSON文件、HTML片段等
//textStatus: 请求状态:success、error、notmodified、timeout四种
}

(2)数据格式:HTML片段、XML文档、JSON文件。

$.post()方法:与$.get()方法结构和使用方法都相同,其不同点:

(1)GET请求会将参数跟在URL后进行传递,而POST请求则是作为HTTP消息的实体内容发送给Web服务器。在Ajax请求中,这种区别对用户不可见。

(2)GET方式对传输的数据大小限制,而POST方式比GET方式大得多。

(3)GET方式请求的数据会被浏览器缓存起来,可以取得浏览器的历史记录,但也具有严重的安全问题。

(4)GET方式和POST方式传递的数据在服务器端的获取不相同。但是两种方式都可以用$_REQUEST[]来获取。

$.getScript()方法和$.geetJson()方法

$.getScript()方法:直接加载.js文件。

$(function(){
$('#send').click(function(){
$getScript('test.js');
});
})

$.getScript()方法也有回调函数,会在JavaScript文件成功载入之后运行。

$.geetJson()方法:用于加载JSON文件,与$.getScript()方法用法相同。

$.each()函数:用于遍历对象和数组。是一个全局函数,不操作jQuery对象,而是以一个数组或者对象作为第一个参数,以一个回调函数作为第二个参数。其中回调函数拥有两个参数:第一个是对象成员或数组索引,第二个为对应变量或内容。

$.ajax()方式

结构为:$.ajax(options)。只有一个参数,但在这个对象里包含了$.ajax()方法所需要的请求设置以及回调函数等信息,参数以key/value形式存在,且所有参数都是可选的。

$.ajax()方法是jQuery最底层烦人Ajax实现,因此可以用它来代替前面提及的所有方法。

【序列化元素】

serialize()方法:作用于一个jQuery对象,能将DOM元素内容序列化为字符串,用于Ajax请求。使用该方法可以将以下代码

$("#send").click(function(){
$.get("get1.php",{
username:$("#username").val(),
content:$("#content").val()
},function(data,textStatus){
$("#resText").html(data); //将返回的数据添加到页面上
});
});

简化为

$("#send").click(function(){
$.get("get1.php",$("#form1").serialize(),function(data,textStatus){
$("#resText").html(data); //将返回的数据添加到页面上
});
});

serialize()方法在其他选择器选取的元素也都能使用该方法:

serializeArry()方法:将DOM元素序列化后,返回JSON格式的数据。

$(function(){
var fields=$(":checkbox.:radio").serializeArry();
console.log(fields); //用Firebug输出
$.each(fields,fuction( i , field ){
$("#results").append(field.value+",");
});
})

$.param()方法:是serialize()方法的核心,用来对一个数组或对象按照key/value进行序列化。

【jQuery中的Ajax全局事件】

<div id="loading">加载中...</div>

当Ajax请求开始时,将此元素显示,当Ajax请求结束后,将此元素隐藏。

$("#loading").ajaxStart(function(){
$(this).show();
});
$("#loading").ajaxStop(function(){
$(this).hide();
}); //也可以用链式写法

如果想使某个Ajax请求不受全局方法的影响,那么可以在使用$.ajax(options)方法时,将参数中的global设置为false。

---恢复内容结束---

jQuery(7)——jQuery与Ajax的应用的更多相关文章

  1. [转载]Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结

    本文对Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法进行了详细的总结,需要的朋友可以参考下,希望对大家有所帮助. 详细解读Jquery各Ajax函数: ...

  2. [jQuery]jQuery DataTables插件自定义Ajax分页实现

    前言 昨天在博客园的博问上帮一位园友解决了一个问题,我觉得有必要记录一下,万一有人也遇上了呢. 问题描述 园友是做前端的,产品经理要求他使用jQuery DataTables插件显示一个列表,要实现分 ...

  3. 关于试用jquery的jsonp实现ajax跨域请求数据的问题

    我们在开发过程中遇到要获取另一个系统数据时,就造成跨域问题,这就是下文要说的解决办法: 先我们熟悉下json和jsonp的区别: 使用AJAX就会不可避免的面临两个问题,第一个是AJAX以何种格式来交 ...

  4. Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结

    本文对Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法进行了详细的总结,需要的朋友可以参考下,希望对大家有所帮助. 详细解读Jquery各Ajax函数:  ...

  5. [转]Spring3 MVC + jQuery easyUI 做的ajax版本用户管理

    原文地址:http://www.iteye.com/topic/1081739 上周写了篇基于spring3.0.5 mvc 简单用户管理实例 ( http://www.iteye.com/topic ...

  6. Comet 反Ajax: jQuery与PHP实现Ajax长轮询

    原文地址(http://justcode.ikeepstudying.com/2016/08/comet-%E5%8F%8Dajax-%E5%9F%BA%E4%BA%8Ejquery%E4%B8%8E ...

  7. 不借助jquery封装好的ajax,你能用js手写ajax框架吗

    不借助jquery封装好的ajax,你能手写ajax框架吗?最基础的ajax框架,一起来围观吧. .创建XMLHttpRequest对象 var xhr = new XMLHttpRequest(); ...

  8. [译]脱离jQuery,使用原生Ajax

    脱离jQuery,使用原生Ajax 标签: Ajax translate 英文出处:<A Guide to Vanilla Ajax Without jQuery> 翻译: 刘健超 J.c ...

  9. 转载 : Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结

    Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结 投稿:jingxian 字体:[增加 减小] 类型:转载 时间:2013-11-14我要评论 本文是 ...

  10. JQuery(三) Ajax相关

    JQuery大大简化了Ajax通用操作,开发者只需要指定请求URL,回调函数即可. 三个主要方法: $().param(obj):将obj参数(对象或数组)转化成查询字符串. {name:" ...

随机推荐

  1. Ubuntu12.10 下搭建基于KVM-QEMU的虚拟机环境(十五)

    接下来我们试验虚拟机的网络配置功能,KVM虚拟机网络配置主要有两种方式:NAT方式和Bridge方式.今天我们主要理解和实验NAT方式的网络配置. NAT方式是kvm安装后的默认方式,它支持主机与虚拟 ...

  2. centos 6.4 x64安装bugfree

    第一步:下载xampp-linux-1.8.1.tar.gz [root@SVNMANAGER ~]# tar -zxvf xampp-linux-1.8.1.tar.gz -C /opt [root ...

  3. canvas中window坐标转换为canvas坐标

    function getMousePos(canvas, evt) { var rect = canvas.getBoundingClientRect(); return { x: evt.clien ...

  4. 关于在freemarker模板中遍历数据模型List<JavaBean>的经验

    本文采用简单的servlet作为后台处理数据的工具,前台使用freemarker的ftl模板作为输出工具,简单说明怎样将封装有实体类对象的List集合注入到ftl模板中并且成功的在遍历显示出来,之前在 ...

  5. 微信小程序开发系列(一)小程序开发初体验

    开发小程序所需的基本技能   关于小程序的介绍和使用场景这里不作介绍,这个系列的文章会一步一步地带领大家快速地学习和掌握小程序的开发. 关于还没有接触过小程序的开发者来说,最关心的问题无非就是,开发小 ...

  6. css修改滚动条默认样式

    之前因为公司项目需要,在网上找到的: 直接上代码了 html代码 <div class="inner"> <div class="innerbox&qu ...

  7. android 在5.0以后不允许使用隐式Intent方式来启动Service

    android5.0以后不能使用隐式intent :需要指定Intent的ComponentName信息:intent.setComponent(xxx),或指定Intent的setPackage(& ...

  8. 数据意识崛起,从企业应用看BI软件的未来发展

    前阵子,和一群企业CIO聊天,希望从甲方角度看看对BI产品的看法.在问及一些成熟企业为何不上BI项目时,大家纷纷表示目前还处于观望状态. 提及BI,大家都觉得有些飘忽,和大数据一样,听着高大上,能真正 ...

  9. For循环输出一个表格

    <!-- 作者:郑伟钊 时间:2017-01-16 描述:通过一个循环的嵌套输出一个表格 --> <?php header("Content-type:text/html; ...

  10. CentOS 7安装SVN以及高版本SVN

    安装 CentOS 7 下yum命令即可方便的完成安装 $ sudo yum install subversion 测试安装是否成功: $ svnserve --version 建立版本库 创建svn ...