1. 什么是Ajax?

Ajax是“Asynchronous Javascript And XML(异步Javascript和XML)”的缩写, 是指一种创建交互式网页应用的网站开发技术。

Ajax不是一种新的编程语言, 而是一种用于创建更好、更快以及交互性更强的web应用程序的技术。

它是一套综合了多项技术的浏览器端网页开发技术。这些技术包括Javascript、 XHTML和CSS、DOM、XML和XMLHttpRequ。

Ajax可以在不重新加载整个页面的情况下, 与服务器交换数据。这种异步交互的方式, 使用户单击后, 不必刷新页面也能获取新数据。 使用Ajax, 用户可以创建接近本地桌面应用的直接、高可用、更丰富、更动态的Web用户界面。

1.1  Ajax原理

通过XTML和CSS来实现页面, 表达信息。

通过浏览器的XmlHttpRequest(Ajax引擎)对象, 来向服务器发送异步请求, 并接收服务器的响应数据, 然后用javascript来操作DOM, 实现动态局部刷新。

1.2 Ajax的优点和不足之处。

优点:

  使用Ajax的最大优点, 就是能在不更新整个页面的前提下维护数据。

  这使得web应用程序更为迅捷地响应用户动作, 并避免了在网络上发送那些没有改变的HTML代码信息。

  1. 减轻服务器负担, 按需要获得数据。

  2. 无刷新更新页面, 减少用户的实际和心理的等待时间。

  3. 更好的用户体验。

  4. 减轻宽带的负担。

  5. 主流浏览器支持。

不足:

  1. Ajax的程序必须测试针对各个浏览器的兼容性。

  2. Ajax更新页面内容的时候并没有刷新整个页面, 因此, 网页的后退功能是失效的。

  3. 对搜索引擎支持不好。

1.3  Ajax实现过程

  第一步: Javascript监听浏览器网页事件(例如:点击, 提交, 更改等)。

  第二步: 由Javascrip创建Ajax引擎对象。

  第三步: 通过Ajax引擎对象发出请求。

  第四步: Ajax引擎等待并且接收服务器的响应内容

  第五步: Javascript再从“Ajax引擎对象”中获取响应内容, 并且通过DOM改变网页界面显示效果。

2. jQuery的load()方法

jQuery load()方法是简单但强大的AJax方法。

load() 方法从服务器加载数据, 并把返回的数据放入被选元素中。

语法:

$("selector").load(URL, data, callback);

第一种情况:

 
$("#btn").click(function(){

     //只传一个URL, 表示在id为new-projectsd的元素加载index.html
  $("#new-projects").load("./index.html") })
 

第二种情况:

$("btn").click(function () {
// 只传一个URL, 导入的index.html文件含有多个传递参数, 类似于: index/html?name=yang&age=12
$("#new-projects").load("./index.html", {"name": "yang", "age":12});
});

第三种情况:

 
$("btn").click(function () {
// 如果加载成功,则会执行回调函数
$("#new-projects").load("./index.html", {"name": "yang", "age":12}, function () {
alert("load执行成功!");
});
});
 

3. jQuery的getJSON方法

jQuery的Ajax中使用getJSON()方法, 异步加载JSON格式数据。

获取服务器中的数据, 并对数据进行解析, 显示到页面中。

语法:

$,getJSON(url, [data], [callback]);

参数(url):  为请求加载json格式文件的服务器地址。

参数(data):  可选, 为请求时发送的数据。

参数(callback): 为数据请求成功后执行的函数。

 
        $.getJSON("./data/getJSON.json", function (data) {
var str=""; //初始化保存内容变量
$.each(data, function (index, ele) {
$("ul").append("<li>"+ele.name+"</li>>")
})
})
 

4. jQuery的$.get()方法

语法:

 $.get(URL, callback);

 参数(URL): 必选, 规定请求的路径。

 参数(callback): 数据请求成功后执行的函数。

 作用:通过HTTP GET请求从服务器上请求数据。

        $.get("./data/getJSON.json", function (data, status) {
console.log(status);
})

5. jQuery的post()方法

语法:

$.post(URL, data, callback);

参数(URL): 必选, 规定请求的路径。

参数(data): 可选, 连同请求发送的数据。

参数(callback):可选, 数据请求成功后执行的函数。

作用: 以POST方式向服务器发送数据, 服务器接收到数据之后, 进行处理, 并将处理结果返回页面。

        $.post("/index", {name: "zhang"}, function (data, status) {
console.log(status);
})

jQuery的Ajax初识的更多相关文章

  1. jQuery之ajax实现篇

    jQuery的ajax方法非常好用,这么好的东西,你想拥有一个属于自己的ajax么?接下来,我们来自己做一个简单的ajax吧. 实现功能 由于jq中的ajax方法是用了内置的deferred模块,是P ...

  2. 【原创经验分享】JQuery(Ajax)调用WCF服务

    最近在学习这个WCF,由于刚开始学 不久,发现网上的一些WCF教程都比较简单,感觉功能跟WebService没什么特别大的区别,但是看网上的介绍,就说WCF比WebService牛逼多少多少,反正我刚 ...

  3. jQuery版AJAX简易封装

    开发过程中,AJAX的应用应该说非常频繁,当然,jQuery的AJAX函数已经非常好用,但是小编还是稍微整理下,方便不同需求下,可以简化输入参数,下面是实例代码: $(function(){ /** ...

  4. JS原生ajax与Jquery插件ajax深入学习

    序言: 近来随着项目的上线实施,稍微有点空闲,闲暇之时偶然发现之前写的关于javascript原生xmlHttpRequest ajax方法以及后来jquery插件ajax方法,于是就行了一些总结,因 ...

  5. 重写jquery的ajax方法

    //首先备份下jquery的ajax方法 var _ajax=$.ajax; //重写jquery的ajax方法 $.ajax=function(opt){ //备份opt中error和success ...

  6. Jquery通过Ajax方式来提交Form表单

    今天刚好看到Jquery的ajax提交数据到服务器的方法,原文是: 保存数据到服务器,成功时显示信息. jQuery 代码: $.ajax({ type: "POST", url: ...

  7. 对jquery的ajax进行二次封装以及ajax缓存代理组件:AjaxCache

    虽然jquery的较新的api已经很好用了, 但是在实际工作还是有做二次封装的必要,好处有:1,二次封装后的API更加简洁,更符合个人的使用习惯:2,可以对ajax操作做一些统一处理,比如追加随机数或 ...

  8. jquery管理ajax异步-deferred对象

    今天跟大家分享一个jquery中的对象-deferred.其实早在jquery1.5.0版本中就已经引入这个对象了.不过可能在实际开发过程中用到的并不多,所以没有太在意. 这里先不说deferred的 ...

  9. Struts2 使用jQuery实现Ajax

    在jQuery中将Ajax相关的操作进行封装,使用时只需在合适的地方调用Ajax相关的方法即可,相比而言,使用jQuery实现Ajax更加简洁,方便 1.$.Ajax()可以通过发送Http请求加载远 ...

随机推荐

  1. 前端必须要掌握的几个CSS3的属性

    随着Css3和html5的风靡,越来越多的前端人员开始学习Css3,今天的文章就是来说说前端应该掌握10个Css3属性. 1. Border-radius Border-radius是一大堆CSS3属 ...

  2. Axure 8 Tab制作

    1 在[页面]面板中选中[page1] 2 在[元件库]中选中[动态面板],并拖拽到[设计区域]中 3 双[设计区域]中的动态面板,打开[动态面板管理]页面 4 在[动态面板管理]页面中输入动态面板的 ...

  3. 请教Nutzwk项目,在beetl页面怎么用shiro标签呢?

    请教Nutzwk项目,在beetl页面怎么用shiro标签呢?  发布于 381天前  作者 WenTao-Love  195 次浏览  复制  上一个帖子  下一个帖子  标签: nutzwk 如题 ...

  4. 【转】Spring 整合 Quartz 实现动态定时任务

    http://blog.csdn.net/u014723529/article/details/51291289 最近项目中需要用到定时任务的功能,虽然spring 也自带了一个轻量级的定时任务实现, ...

  5. 在matlab中查看变量的数据类型

    >> x = x = >> class(x) ans = double

  6. 【JS-Java-EL】JavaScript和Java(EL表达式)引发的 Uncaught SyntaxError: Unexpected token ILLEGAL

    2018.10.14 BUG原因: 在较早期的代码中,容易出现 JS 拼接 HTML 代码字符串的情况.如 // 页面 test.jsp 内部的 JS 代码 // ${} JSP中EL语法,内部为Ja ...

  7. 第43章 RTC—实时时钟—零死角玩转STM32-F429系列

    第43章     RTC—实时时钟 全套200集视频教程和1000页PDF教程请到秉火论坛下载:www.firebbs.cn 野火视频教程优酷观看网址:http://i.youku.com/fireg ...

  8. 《JavaScript高级程序设计第三版》——细碎知识痛点整理(第六章)

    面向对象的程序设计 对象是一组没有特定顺序的值6.1.1 属性类型ECMAScript中有两种属性:数据属性和访问器属性.1. 数据属性Configurable 表示能否通过delete删除属性从而重 ...

  9. java基础 静态 static 问在多态中,子类静态方法覆盖父类静态方法时,父类引用调用的是哪个方法?

    多态 package com.swift.jiekou; public class Jicheng_Tuotai_jingtai_diaoyong { public static void main( ...

  10. C++编程经验总结1

    面向对象的精髓: 主函数其实就是对于类的元素和动作的重新组合来进行一项活动. 一个思想概念:程设是清楚的,完美的. 数学是清楚的,是完美的. 物理是有趣的,尤其是量子物理 生物是清楚的,尤其是基因 外 ...