`
z_xiaofei168
  • 浏览: 198029 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

ajax的核心技术解析

    博客分类:
  • Ajax
阅读更多

 ajax的核心技术解析
      读音:e:j^ks 。AJAX即“Asynchronous JavaScript and XML”(异步JavaScript和XML),AJAX并非缩写词,而是由Jesse James Gaiiett创造的名词,是指一种创建交互式网页应用的网页开发技术。Ajax:一种不用刷新整个页便可与服务器通讯的办法
   
Ajax的技术的产生
     Ajax被认为是(Asynchronous JavaScript and XML的缩写)。现在,允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax.“Ajax”这个名字是在2005年2月,Adaptive Path的Jesse James Garrett在他的文章Ajax:A New Approach to Web Application中创造。而 Ajax 这项技术,是 Google 在Google Labs发布Google Maps和Google Suggest后真正为人所认识。

 

同步交互和异步交互
举个例子:普通B/S模式(同步)       AJAX技术(异步)
    同步:提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事
    异步: 请求通过事件触发->服务器处理(这时浏览器仍然可以作其他事情)->处理完毕
    同步是指:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式。 
    异步是指:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式
    
    易懂的理解:
    异步传输:   你传输吧,我去做我的事了,传输完了告诉我一声  
    同步传输:   你现在传输,我要亲眼看你传输完成,才去做别的事


不用刷新整个页面便可与服务器通讯的办法:
1、Flash
2、Java applet
3、框架:如果使用一组框架构造了一个网页,可以只更新其中一个框架,而不必惊动整个页面
隐藏的iframe
4、XMLHttpRequest:该对象是对 JavaScript 的一个扩展,可使网页与服务器进行通信。是创建 Ajax 应用的最佳选择。实际上通常把 Ajax 当成 XMLHttpRequest 对象的代名词

 

Ajax的工作原理

Ajax的核心是JavaScript对象XmlHttpRequest。
1、该对象在Internet Explorer 5中首次引入,它是一种支持异步请求的技术。简而言之,XmlHttpRequest使您可以使用JavaScript向服务器提出请求并处理响应,而不阻塞用户。
2、AJAX采用异步交互过程。AJAX在用户与服务器之间引入一个中间媒介,从而消除了网络交互过程中的处理—等待—处理—等待缺点。
3、用户的浏览器在执行任务时即装载了AJAX引擎。AJAX引擎用JavaScript语言编写,通常藏在一个隐藏的框架中。它负责编译用户界面及与服务器之间的交互。
4、AJAX引擎允许用户与应用软件之间的交互过程异步进行,独立于用户与网络服务器间的交流。现在,可以用Javascript调用AJAX引擎来代替产生一个HTTP的用户动作,内存中的数据编辑、页面导航、数据校验这些不需要重新载入整个页面的需求可以交给AJAX来执行。
5、使用AJAX,可以为JSP、开发人员、终端用户带来可见的便捷


Ajax工具包

Ajax并不是一项新技术,它实际上是几种技术,每种技术各尽其职,以一种全新的方式聚合在一起
服务器端语言:服务器需要具备向浏览器发送特定信息的能力。Ajax与服务器端语言无关。
1、XML (eXtensible Markup Language,可扩展标记语言) 是一种描述数据的格式。Aajx 程序需要某种格式化的格式来在服务器和客户端之间传递信息,XML 是其中的一种选择
2、XHTML(eXtended Hypertext Markup Language,使用扩展超媒体标记语言)和 CSS(Cascading Style Sheet,级联样式单)标准化呈现;
3、DOM(Document Object Model,文档对象模型)实现动态显示和交互;
4、使用XMLHTTP组件XMLHttpRequest对象进行异步数据读取
5、使用JavaScript绑定和处理所有数据


AJAX的缺陷

AJAX不是完美的技术。也存在缺陷:
1    AJAX大量使用了Javascript和AJAX引擎,而这个取决于浏览器的支持。IE5.0及以上、Mozilla1.0、NetScape7及以上版本才支持,Mozilla虽然也支持AJAX,但是提供XMLHttpRequest的方式不一样。所以,使用AJAX的程序必须测试针对各个浏览器的兼容性。
2   AJAX更新页面内容的时候并没有刷新整个页面,因此,网页的后退功能是失效的;有的用户还经常搞不清楚现在的数据是旧的还是已经更新过的。这个就需要在明显位置提醒用户“数据已更新”。
3    对流媒体的支持没有FLASH、Java Applet好。
4    一些手持设备(如手机、PDA等)现在还不能很好的支持Ajax。


说了这么多,下面我们就做一个ajax的案例:

第一个案例是ajax的get方法:

getAjax.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
	String path = request.getContextPath();
	String basePath = request.getScheme() + "://"
			+ request.getServerName() + ":" + request.getServerPort()
			+ path + "/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
	<head>
		<base href="<%=basePath%>">

		<title>My JSP 'getAjax.jsp' starting page</title>

		<meta http-equiv="pragma" content="no-cache">
		<meta http-equiv="cache-control" content="no-cache">
		<meta http-equiv="expires" content="0">
		<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
		<meta http-equiv="description" content="This is my page">
		<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

	</head>

	<body>
		
		<input type="button" value="AjaxGet请求" onclick="getAjax()"/>
		<div id="content"></div>

	</body>
</html>
<script>
function $(id) {
	return document.getElementById(id);
}
//getAjax请求
//创建XMLHttpRequest对象
function getXhr() {
	var xhr;
	try {
		//IE浏览器
		xhr = new ActiveXObject("Microsoft.XMLHTTP");
	} catch (err) {
		try {
			//firefox opera 等其他浏览器
			xhr = new XMLHttpRequest();
		} catch (er) {
			alert("您的浏览器不支持ajax技术的操作,请您升级.....");
		}

	}

	return xhr;
}

function getAjax(){
     
     //获取xhr对象
     var xhr = getXhr();
     //规定请求类型
  
     /*
     open(method,url,async)
         method:get ,post /get与post的区别总结出来
                /get 地址栏中显示? & 2k
                /post:url
        url:相对路径 也可以使绝对路径
      
        async:true异步 false 同步
     */
     
        xhr.open("get","main.jsp?username=123",true);
        
        //get请求 就不必要设置 xhr.setRequestHeader(header,value)
        
        //发送请求,如果是get请求send(参数)参数:必须是null或者xhr.send();
        //备注:如果xhr.send(参数);参数不为空情况下,会自动转换成post请求方式
        //您可以通过request.getMethod();方法获取请求的方式
        xhr.send();
        /*当发送请求时:readyState对象状态会自动改变并且有服务器端发送给客户端
        * readyState的每次改变都会自动处理onreadystatechanage事件
       
          readystate的值:
           0:未处理
           1:读取中
           2:已读取
           3:交互中
           4:完成
         值的每一次改变都会处理:onreadystatechanage事件 事件可以采用以下两种方式处理
             1、xhr.onreadystatechange=function(){}
             2、xhr.onreadystatechange= 函数的名字;
        */
        xhr.onreadystatechange = function (){
        
          //判读是否处理完毕
          if(xhr.readyState==4){
               //判读服务器是否处理成功!
              if(xhr.status==200){
                  $("content").innerHTML = xhr.responseText;
              }
          
          }
            
        
        } 
        
}

</script>

 

 

main.jsp

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
   out.println("<font color='red'>服务器处理完毕</font>");
  
   //获取请求的方法 
    String method =  request.getMethod();
   out.println("<br/>您是通过<font color='red'>"+method+"</font>方法向服务器发送请求的!");
   //获取传递的参数
   out.println(request.getParameter("username"));
%>

 

 

第二个案例是ajax的post方法:

 

 

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
	String path = request.getContextPath();
	String basePath = request.getScheme() + "://"
			+ request.getServerName() + ":" + request.getServerPort()
			+ path + "/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
	<head>
		<base href="<%=basePath%>">

		<title>My JSP 'getAjax.jsp' starting page</title>

		<meta http-equiv="pragma" content="no-cache">
		<meta http-equiv="cache-control" content="no-cache">
		<meta http-equiv="expires" content="0">
		<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
		<meta http-equiv="description" content="This is my page">
		<!--
	<link rel="stylesheet" type="text/css" href="styles.css">
	-->

	</head>

	<body>
		<form action="" enctype="application/x-www-form-urlencoded"></form>
		<input type="button" value="AjaxPost请求" onclick="postAjax()"/>
		<div id="content"></div>

	</body>
</html>
<script>
function $(id) {
	return document.getElementById(id);
}
//getAjax请求
//创建XMLHttpRequest对象
function getXhr() {
	var xhr;
	try {
		//IE浏览器
		xhr = new ActiveXObject("Microsoft.XMLHTTP");
	} catch (err) {
		try {
			//firefox opera 等其他浏览器
			xhr = new XMLHttpRequest();
		} catch (er) {
			alert("您的浏览器不支持ajax技术的操作,请您升级.....");
		}

	}

	return xhr;
}

function postAjax(){
     
     //获取xhr对象
     var xhr = getXhr();
     //规定请求类型
  
     /*
     open(method,url,async)
         method:get ,post /get与post的区别总结出来
                /get 地址栏中显示? & 2k
                /post:url
        url:相对路径 也可以使绝对路径
      
        async:true异步 false 同步
     */
     
        xhr.open("post","main.jsp",true);
        
        //post请求在传递值的情况下必须设置 xhr.setRequestHeader(header,value)
        
        xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
        //发送请求,如果是post请求send(参数)参数:参数可以是null或者xhr.send()|send(带有参数的)
        xhr.send("username=345&pass=123");
        /*当发送请求时:readyState对象状态会自动改变并且有服务器端发送给客户端
        * readyState的每次改变都会自动处理onreadystatechanage事件
       
          readystate的值:
           0:未处理
           1:读取中
           2:已读取
           3:交互中
           4:完成
         值的每一次改变都会处理:onreadystatechanage事件 事件可以采用以下两种方式处理
             1、xhr.onreadystatechange=function(){}
             2、xhr.onreadystatechange= 函数的名字;
        */
        xhr.onreadystatechange = function (){
        
          //判读是否处理完毕
          if(xhr.readyState==4){
               //判读服务器是否处理成功!
              if(xhr.status==200){
                  //$("content").innerHTML = xhr.responseText;
                  alert(xhr.responseText);
              }
          
          }
            
        
        } 
        
}

  

</script>

 

 

 

 


 

4
5
分享到:
评论

相关推荐

    jQuery_Ajax_实例_全解析(原作者版)

    快速把握jQuery_Ajax核心技术,成为软件开发达人!

    北京中科信软AJAX培训

    Ajax核心技术-XML XML与Ajax 文档类型定义及声明 XML名域 操纵和解析XML 选择合适的XML生成方式 XHTML与CSS XHTML、CSS与Ajax XHTML与CSS基础 XHTML语法约束 JavaScript JavaScript与Ajax JavaScript基本数据结构 ...

    Ajax和跨域问题深入解析

    Ajax的核心就是XMLHttpRequest(XHR)对象.XHR为向服务器发送请求和解析服务器响应提供了流畅的接口.可以使用XHR对象获取新数据,通过DOM将新数据插入到页面.虽然名字中包含XML,但是ajax通信和数据格式无关;这种技术...

    大名鼎鼎的IBM公司 Ajax 培训资料

    在谈到 Ajax 时,实际上涉及到多种技术,要灵活地运用它必须深入了解这些不同的技术(本系列的头几 篇文章将分别讨论这些技术)。好消息是您可能已经非常熟悉其中的大部分技术,更好的是这些技术都很 容易学习,并不...

    JSON 核心技术应用

    尽管有许多宣传关于 XML 如何拥有跨平台,跨语言的优势,然而,除非应用于 Web Services,否则,在普通的 Web 应用中,开发者经常为 XML 的解析伤透了脑筋,无论是服务器端生成或处理 XML,还是客户端用 JavaScript ...

    开涛高可用高并发-亿级流量核心技术

    3.11.1 请求解析和业务处理线程池分离 57 3.11.2 业务线程池隔离 58 3.11.3 业务线程池监控/运维/降级 58 3.11.4 如何使用Servlet 3异步化 59 3.11.5 一些Servlet 3异步化压测数据 64 4 限流详解 66 4.1 限流算法 67...

    解析移动 Web 2.0

    数据是下一个的“Intel Inside”软件发布周期的终结,轻型编程模式像RSS和AJAX这样相对简单的技术是在web2.0服务后面对抗像使用SOAP这类机制的web服务的驱动力。软件在单一设备的上层,当如RSS之类的机制被用来同步...

    AJAX应用的通用流程

    XMLHttpRequest 是 AJAX应用程序的核心,而且对很多读者来说可能还比较陌生,我们就从这里开始吧。从 清单 1 可以看出,创建和使用这个对象非常简单,不是吗?等一等。 还记得几年前的那些讨厌的浏览器战争吗?...

    Ajax的概述与实现过程

    2、Ajax技术的核心是XMLHttpRequest对象(简称XHR),这是由微软首先引入的一个特性。在XHR出现之前,Ajax式的通信必须借助一些hack手段来实现,大多数是使用隐藏的框架或内嵌框架。 3、XHR为向服务器发送请求和解析...

    ExtJS(ajax框架) 4.2.1

    ExtJs最开始基于YUI技术,由开发人员 JackSlocum开发,通过参考JavaSwing等机制来组织可视化组件,无论从UI界面上CSS样式的应用,到数据解析上的异常处理,都可算是 一款不可多得的JavaScript客户端技术的精品。 ...

    Ajax定义浅要剖析

    Ajax是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。   个人理解: 触发某个事件-&gt;向服务端发起请求-&gt;返回响应(数据)-&gt;局部更新 在一般的通讯方式当中,我们是通过在浏览器地址栏输入相关链接,...

    深入理解ajax系列第一篇之XHR对象

     ajax技术的核心是XMLHttpRequest对象(简称XHR),这是由微软首先引入的一个特性,其他浏览器提供商后来都提供了相同的实现。XHR为向服务器发送请求和解析服务器响应提供了流畅的接口,能够以异步方式从服务器取得更...

    2024年的必考python爬虫面试题10个.zip

    python爬虫内容概要: 本套面试题涵盖了Python爬虫的基本原理、反爬虫策略、常用库(如BeautifulSoup、Scrapy、Selenium)的使用、代理IP的应用、Ajax爬取、多线程/多进程提高效率、分布式爬虫的实现等核心技术点。...

    javaweb详细笔记,绝对详细(内含代码)

    javaweb ...知识点 Javascript知识点 jQuery知识点 14 Bootstrap知识点 17 JDBC & 配置文件 & 连接池 19 Xml文档及解析 31 ...Js原生Ajax和Jquery的Ajax 71 监听器Listener 74 邮箱服务器 79 过滤器Filter

    基于Java Spring的科技大学博客社区系统的设计与实现毕业设计 含论文、源代码、数据库、答辩PPT等资料 直接可用.rar

    通过AJAX技术实现前后端数据交互。 后端采用Java技术,底层通过解构HTTP1.1通信协议,实现一款高能可用的FlyServer服务器。通过架构实现以BIO、NIO为核心的I/O模型的ServerSocket,解构HTTP1.1协议内容,并且封装...

    搞定J2EE:STRUTS+SPRING+HIBERNATE整合详解与典型案例 (2)

    1.4 J2EE核心技术 1.4.1 Servlet 1.4.2 JSP(Java服务页面) 1.4.3 EJB(企业JavaBean) 1.4.4 JDBC(Java数据库连接) 1.4.5 JTA/JTS(Java事务) 1.4.6 JNDI(Java命名和目录服务) 1.4.7 JavaMail(Java邮件服务...

    达内java培训目录

    持久层框架技术 ORM概念、Hibernate核心API、Hibernate实体映射技术、Hibernate关系映射技巧、HQL查询、OSCache及Hibernate缓存技术; 掌握JQuery核心API;了解JQuery基本设计原则;了解多种JQuery插件;掌握DWR的...

    AJAX应用中必须要掌握的重点知识(分享)

    AJAX是什么? 是Asynchronous Javascript And XML的首...AJAX的核心? XMLHTTPRequest,简写XHR,Xml可扩展标记语言,Http超文本传输协议,Request请求。XMLHttpRequest对象可以在不向服务器提交整个页面的情况下,实现局

    锋利的jQuery(第2版).单东林、张晓菲、魏然(带详细书签)

    AJAX的核心对象XMLHttpRequest jQuery API速查表 jQuery中的$.ajax方法 《锋利的jQuery(第2版)》循序渐进地对jQuery的各种函数和方法调用进行了介绍,读者可以系统地掌握jQuery的选择器、DOM操作、事件和动画、AJAX...

Global site tag (gtag.js) - Google Analytics