AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML)

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

XMLHttpRequest用于在后台与服务器交换数据。 XMLHttpRequest 对象提供了对 HTTP 协议的完全的访问,包括做出 POST 和 HEAD 请求以及普通的 GET 请求的能力。XMLHttpRequest 可以同步或异步返回 Web 服务器的响应,并且能以文本或者一个 DOM 文档形式返回内容。尽管名为 XMLHttpRequest,它并不限于和 XML 文档一起使用:它可以接收任何形式的文本文档。

所有现代浏览器 (IE7+、Firefox、Chrome、Safari 以及 Opera) 都内建了 XMLHttpRequest 对象。

老版本的IE浏览器(ie5,6使用)Activex对象。

我们要认识一个协议:HTTP(超文本传输协议),它是一种无状态的协议,意思就是不建立持久链接,每次向web服务器请求连接,得到响应之后断开,下一次请求需要重新建立连接。

如何用XMLHttprequest对象发送http请求:

  1. open(method,url,async)

  method:表示请求类型,GET,POST(不区分大小写)

  url:文件在服务器上的位置,可以是相对地址,也可以是绝对地址

  async:true(同步),false(异步),默认的是异步

2,send(string)

  有一个参数,对于GET请求,它的数据都拼在url地址中,所以该方法仅限于POST方法

下面是一些例子:

分析:对于第二种,post请求没有给出参数,在实际中意义不大,通常都是第三种,send一些信息。

  setRequestHeader 设置http的头信息,告诉Web服务器,要发送一个表单,注意位置,要放在open和send中间,否则,会抛出一个异常。

如何获取服务器给出的响应:

我们可以监听readyState属性的变化,该属性变化代表着服务器响应的变化

我们可以通过onreadystatechange这个事件监听属性的变化,在每次readyState属性发生变化时,触发这个事件。我们一般监听响应是否完成,主要是监听readyState属性状态为4

当响应完成,且请求发送成功,我们就可以做一些事情,比如获取服务器响应的内容,然后在页面上做一些呈现


JSON(JavaScript Object Notation) javascript对象表示法

JSON 是存储于交换文本信息的语法,类似XML,采用键值对的方式来组织,易于人们阅读和编写,同时也易于机器解析和生成。

JSON是独立于语言的,也就是说不论什么语言都可以解析成JSON,只要按照JSON的规则来就行。

JSON的优点:1,json的长度和xml比起来更短小,在网络中传输可以大大的减小带宽,  

       2,json的读写速度更快

      3,json可以使用javascript内建的方法直接进行解析,转换成javascript对象,非常方便。

JSON的书写格式:名称/值对

  名称写在前面,写在双引号中,值对写在后面,也写在双引号中。中间用冒号隔开。

  json的值可以是下面几种类型:

  •   数字(整数和浮点数)
  •   字符串(在双引号中)
  •   逻辑值(true  false)
  •   数组(在方括号中)
  •   对象(在花括号中)
  •   null

分析:上面是个典型的JSON字符串,首先放在一个花括号中,表示是一个json对象,对象中有一个值对,名称叫“staff”,值是一个数组,这个数组又有很多小的json对象来组成,每个对象里面又有两个属性

JSON的解析有两种方式:

eval和JSON.parse。在代码中执行eval,是很危险的,特别是执行第三方的JSON数据(其中可能包含恶意代码),所以尽可能的使用JSON.parse()解析字符串本身,该方法可以捕捉到JSON中的语法错误。用eval()方法不仅解析了JSON字符串,还执行了JSON字符串中的一些方法,也就是说用eval()方法,它不会看JSON字符串是否合法。

这里推荐一款叫JSONlint的工具:http://jsonlint.com/      可以校验JSON字符串中的语法错误。

对于服务器端PHP,转换成JSON格式,我们可以做如下的改动:

1,首先将header("Content-Type:application/json;charset=utf-8");

 2,然后将所有的输出改为JSON格式

3,然后将客户端,服务器传来的值 request.responseText 用JSON.parse()方法解析,解析之后,我们可以直接读取服务器传来对象的属性。


jQuery中的Ajax 

通常我们不会用原生的javascript来写ajax,我们会用第三方的js库,例如jQuery库,这些js库中已经封装了类似于ajax请求的方法,这样,我们在使用中,就可以不用关注浏览器的兼容性,调用方法。可以大大简化我们的操作。jquery中本身提供了一个ajax方法:

Ajax全接触的更多相关文章

  1. 三、jQuery--Ajax基础--Ajax全接触--jQuery中的AJAX

    用jQuery实现Ajax jQuery.ajax([settings]) type:类型,“POST”或“GET”,默认为“GET” url:发送请求的地址 data:是一个对象,连同请求发送到服务 ...

  2. 三、jQuery--Ajax基础--Ajax全接触--Ajax在JS中的应用

    Ajax的全称:Asynchronous JavaScript And XML(异步的 JavaScript 和 XML). Ajax不是某种编程语言,是一种在无需重新加载整个网页的情况下能够更新部分 ...

  3. Ajax全接触(2)

    例子简介 1.查询员工信息,可以通过输入员工编号查询员工基本信息: 2.新建员工信息,包含员工姓名,员工编号,员工性别,员工职位: 实现: 1.纯html页面,用来实现员工查询和新建的页面: 2.ph ...

  4. Ajax全接触(1)

    Ajax全称:Asynchronous JavaScript and XML(异步的JavaScript和XML) .Ajax不是某种编程语言 是一种在无需重新加载整个网页的情况之下能够更新部分网页的 ...

  5. 三、jQuery--Ajax基础--Ajax全接触--扩展知识(跨域)

  6. 三、jQuery--Ajax基础--Ajax全接触--JSON

    JSON基本概念 JSON:JavaScript对象表示法(JavaScript Object Notation) JSON是存储和交换文本信息的语法,类似XML.它采用键值对的方式来组织,易于人们阅 ...

  7. .NET_RSA加密全接触(重、难点解析)

    .NET_RSA加密全接触(重.难点解析) .NET Framework提供了两个类供我们使用RSA算法,分别是:用于加密数据的RSACryptoServiceProvider和用于数字签名的DSAC ...

  8. jQuery Ajax 全解析

    转自:http://www.cnblogs.com/qleelulu/archive/2008/04/21/1163021.html 本文地址: jQuery Ajax 全解析 本文作者:QLeelu ...

  9. 【转】Microsoft .Net Remoting之Remoting事件处理全接触

    Remoting事件处理全接触 前言:在Remoting中处理事件其实并不复杂,但其中有些技巧需要你去挖掘出来.正是这些技巧,仿佛森严的壁垒,让许多人望而生畏,或者是不知所谓,最后放弃了事件在Remo ...

随机推荐

  1. Math-基本功能

    <script type="text/javascript"> /* *演示Math对象.该对象中的方法都是静态的.不需要new,直接Math调用即可 */ var n ...

  2. Nginx下TIME_WAIT过多的调优

    查看Nginx并发状态 #netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}' TIME_WAIT 1259SYN_ ...

  3. 线性探测再散列 建立HASH表

    根据数据元素的关键字和哈希函数建立哈希表并初始化哈希表,用开放定址法处理冲突,按屏幕输出的功能表选择所需的功能实现用哈希表对数据元素的插入,显示,查找,删除. 初始化哈希表时把elem[MAXSIZE ...

  4. Redis常用的30个命令

    转自http://www.jb51.net/article/51884.htm 1,connect 描述:实例连接到一个Redis.参数:host: string,port: int返回值:BOOL ...

  5. SQLServer性能调优3之索引(Index)的维护

    前言 前一篇的文章介绍了通过建立索引来提高数据库的查询性能,这其实只是个开始.后续如果缺少适当的维护,你先前建立的索引甚至会成为拖累,成为数据库性能的下降的帮凶. 查找碎片 消除碎片可能是索引维护最常 ...

  6. Map的简单语法

    package jaxpsax; import java.util.Collection; import java.util.HashMap; import java.util.Iterator; i ...

  7. [HTML5]移动开发不同手机弹出数字键盘问题

    这里还是先那么先交代一下遇到的问题.其实无论是tel还是number都不是完美的:type="tel"优点是iOS和Android的键盘表现都差不多缺点是那些字母好多余,虽然我没有 ...

  8. copy file to docker、

    Docker是个Linux Container管理软件. 今天我们来讲解一下从主机复制文件到Docker的几种方法. 在分享之前, 我们看看Docker社区对这个问题的需求是有多么强(ju)烈(jin ...

  9. python 清楚数组重复字符串元素

    l1 = ['bb','c','d','bb','c','a','a'] l2 = {}.fromkeys(l1).keys() print (l2)

  10. 《zw版·Halcon-delphi系列原创教程》 Halcon分类函数012,polygon,多边形

    <zw版·Halcon-delphi系列原创教程> Halcon分类函数012,polygon,多边形 为方便阅读,在不影响说明的前提下,笔者对函数进行了简化: :: 用符号“**”,替换 ...