我是专注于软件开发和IT教育的孙鑫老师,出版过多本计算机图书,包括《Java Web开发详解》、《VC++深入详解》、《Struts 2深入详解》、《Servlet/JSP深入详解》、《XML、XML Schema、XSLT 2.0和XQuery开发详解》、《HTML5、CSS和JavaScript开发》、《Vue.js从入门到实战》、《Java无难事》、《Vue.js 3.0从入门到实战》。
喜欢我的文章欢迎关注、转发、评论、点赞和收藏,我会经常与大家分享IT技术、编程语言的文章和教学视频。目前已发布完整的《Vue.js从入门到实战》和《Java无难事》教学视频,正在发布《Vue.js 3.0从入门到实战》一书教学视频。
现在学习前端开发的同学很多,很多JavaScript库与框架都封装了Ajax调用,但初学者对于Ajax的原理并不了解,导致在学习时一知半解,为此,我将之前写的书中的章节发布出来,帮助大家更好的理解和学习前端开发。
Ajax简介
Ajax的全称是Asynchronous JavaScript and XML,即异步JavaScript和XML。Ajax最早是由Adaptive Path公司的咨询顾问Jesse James Garrett在2005年2月提出的,Garrett专门写了一篇文章来讲述Ajax这一新的Web开发方式,文章名为“Ajax: A New Approach to Web Applications”,有兴趣的读者可以从下面的网址处看到这篇文章:
http://www.adaptivepath.com/ideas/essays/archives/000385.php
Garrett将XHTML和CSS、DOM、XML和XSLT、XMLHttpRequest和JavaScript多种技术的综合应用称之为Ajax,换句话说,Ajax并不是一种技术,它是多种技术的组合,包括:
使用XHTML和CSS来呈现数据;
使用DOM实现动态显示和交互;
使用XML和XSLT实现数据交换与操作;
使用XMLHttpRequest实现异步数据的发送与接收;
使用JavaScript将XHTML、DOM、XML和XMLHttpRequest绑定。
实际上,早在Garrett发表文章为Ajax命名之前,Ajax就已经在一些Web系统中应用了。Google是最早采用Ajax的公司之一,它在一些产品中使用了Ajax,如Google Suggest、Google Maps和Gmail等,也正是因为Ajax在这些产品中的成功应用,极大地鼓舞了开发人员在Web系统中使用Ajax的信心,使得Ajax得以迅速推广。
Ajax为用户带来了更好的用户体验。在传统的Web应用程序中,用户向服务器发送一个请求,然后等待,服务器对用户请求进行处理,然后返回一个响应。这是一种同步的处理方式,如果服务器处理请求的时间比较长,那么用户将不得不长时间的等待,“呆呆地”盯着空白的浏览器窗口。
传统的Web应用程序模型和它的同步传输机制分别如图1和图2所示。
图1 传统的Web应用程序模型
图2 传统的Web应用程序模型(同步传输)
长久以来,我们对这种Web交互模式已经习以为常,以为Web就是这么用的,直到Ajax的出现。
与传统的Web应用程序不同,Ajax采用了异步交互机制,从而避免了用户请求-等待-响应这种交互方式的缺点。Ajax应用程序在用户和服务器之间引入了一个中间层——Ajax引擎,它是用JavaScript编写的,在一个隐藏的框架中运行。Ajax引擎负责呈现用户界面,以及代表用户与服务器进行交互。Ajax引擎允许用户与服务器端的Web程序之间的交互异步地进行,这样用户就无须“呆呆地”看着空白的浏览器窗口和一个沙漏图标,等待服务器返回响应页面了。使用了Ajax的Web应用程序的模型和它的异步传输机制分别如图3和图4所示。
图3 Ajax Web应用程序模型
图4 Ajax Web应用程序模型(异步传输)
DOM
DOM是Document Object Model的缩写,即文档对象模型,它是W3C组织推荐的处理XML的标准接口。2004年4月7日,W3C组织发布了DOM Level3 Core的推荐标准,有关DOM的技术报告可以在
http://www.w3.org/DOM/DOMTR.html上查看。
DOM是独立于程序设计语言的,W3C组织以IDL(Interface Definition Language,接口定义语言)的形式定义了DOM中的接口。某种程序语言要实现DOM,需要将DOM接口转换为本语言中的适当结构,为了保证不同语言的不同DOM之间实现广泛的兼容,W3C组织在DOM规范的附录部分提供了Java和ECMAScript这两种语言的语言绑定。
DOM中的核心概念就是节点。DOM在分析HTML和XML文档时,将组成HTML和XML文档的各个部分(元素、属性、文本、注释等)映射为一个对象,这个对象就叫做节点。在内存中,这些节点形成一棵文档树。整棵树是一个节点,树中的每一个节点也是一棵树(子树),可以说,DOM就是对这棵树的一个对象描述,我们通过访问树中的节点来存取HTML和XML文档的内容。
使用DOM,我们不但可以访问HTML的各个节点,还可以编辑HTML文档的内容,从而创建动态的页面。
例如,HTML页面有一个表格,代码如例1所示。
例1 显示图书信息的表格
书名
作者
《Java无难事》
孙鑫
如果我们想要为这个表格动态添加一行图书信息,在JavaScript中可以使用DOM来实现这一功能,代码如例2所示。
例2 使用DOM动态提交图书信息
<script type="text/javascript">
var row = document.createElement("tr");
cell = createCellWithText("《Vue.js 3.0从入门到精通》");
//将单元格作为子节点添加到元素中
row.appendChild(cell);
cell = createCellWithText("孙鑫");
row.appendChild(cell);
//将新创建的表行添加到 元素中
document.getElementById("booksBody").appendChild(row);
//定义创建单元格的函数
function createCellWithText(text) {
var cell = document.createElement("td");
var textNode = document.createTextNode(text);
cell.appendChild(textNode);
return cell;
}
</script>提示: DOM和JavaScript并不是一回事。DOM是面向HTML和XML的API,为文档提供了结构化的表示。JavaScript是一种语言,它提供了DOM的实现。在JavaScript中,除了可以使用DOM API,还可以使用其他的API。
XMLHttpRequest
XMLHttpRequest对象是整个Ajax技术的核心,正是因为有了这个对象,异步交互才有可能实现。XMLHttpRequest最早是在IE 5中以ActiveX组件的形式实现的,它可以直接向服务器传输数据,而不需要由页面来发送请求,同时它还可以直接从服务器接收响应,而不需要刷新页面。
IE把XMLHttpRequest实现为一个ActiveX对象,其他的浏览器(Firefox、Safari和Opera)则把它实现为一个本地的JavaScript对象。因此,为了兼容不同的浏览器,你需要按照例3所示的方式来创建XMLHttpRequest对象。
例3 兼容不同浏览器的XMLHttpRequest对象的创建方式
var xmlHttp;
function createXMLHttpRequest() {
if(window.ActiveXObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
else if(window.XMLHttpRequest) {
xmlHttp = new XMLHttpRequest();
}
}
XMLHttpRequest的方法如表1所示。
表1 XMLHttpRequest的方法
方 法
说 明
abort()
终止当前请求
getAllResponseHeaders()
以字符串的形式返回所有的响应报头
getResponseHeader(String header)
获取指定的响应报头的值
open(String method,String uri)
建立对服务器的调用。method参数可以是GET、POST或HEAD。url参数可以是相对URL或绝对URL。该方法还有三个可选的参数
send(content)
向服务器发送请求
setRequestHeader(String header, String value)
设置请求的报头信息。在设置任何报头之前,必须先调用open()方法
XMLHttpRequest的属性如表2所示。
表2 XMLHttpRequest的属性
属 性
说 明
onreadystatechange
每个状态改变时都会触发这个事件处理器,通常是一个JavaScript函数
readyState
请求的状态。有5个可能的取值:0(未初始化)、1(请求已建立,但还没有发送)、2(请求已发送,但还没有收到响应)、3(正在接收,通常响应中的部分数据已经可用,但还没有完全接收完毕)、4(响应已完成)
responseText
服务器的响应,表示为文本内容
responseXML
服务器的响应,表示为XML。这个对象可以解析为一个DOM对象
status
服务器的HTTP状态代码,如200对应OK,404对应Not Found等。仅当readyState值为3或4时,该属性才可用
statusText
HTTP状态代码的描述文本,如OK、Not Found等。仅当readyState值为3或4时,该属性才可用
statusText
HTTP状态代码的描述文本,如OK、Not Found等。仅当readyState值为3或4时,该属性才可用
我们看一个使用XMLHttpRequest发送请求和接收响应的例子,代码如例4所示。
例4 使用XMLHttpRequest发送请求和接收响应的例子
var xmlHttp;
if(window.ActiveXObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
else if(window.XMLHttpRequest) {
xmlHttp = new XMLHttpRequest();
}
var email = document.getElementById("email");
var url = validate?email=" + escape(email.value);
xmlHttp.open("GET", url);
xmlHttp.onreadystatechange=handleStateChange;
xmlHttp.send(null);
//处理服务器响应的回调函数
function handleStateChange() {
//判断响应是否完成
if(xmlHttp.readyState == 4) {
//判断响应是否成功
if(xmlHttp.status == 200) {
alert(xmlHttp.responseText);
}
}
}
XMLHttpRequest Level2
XMLHttpRequest API使得Ajax技术的实现成为了可能,作为XMLHttpRequest的改进版, XMLHttpRequest Level 2在功能上有了很大的改进,主要包括:
- 跨源XMLHttpRequest
- 进度事件(Progress event)
跨源HTTP请求包括一个Origin头部,它为服务器提供HTTP请求的源信息。头部由浏览器保护,不能被应用程序代码更改。
使用跨源XMLHttpRequest可以构建基于非同源服务的Web应用程序。
1、新增事件
事件名称
说明
loadstart
当请求开始
progress
在发送和加载数据期间
abort
请求已被终止。如调用abort()方法
error
当请求已失败
load
当请求已成功完成
timeout
在请求完成之前指定的超时值到了
loadend
当请求已完成(无论成功或失败)
2、检测浏览器对XMLHttpRequest2的支持
var xhr = new XMLHttpRequest() ;
if (typeof xhr.withCredentials === undefined){
// 您的浏览器不支持跨源的XMLHttpRequest
}
3、示例
跨源上传
<script>
var xmlHttp;
function checkSupport(){
xmlHttp = window.XDomainRequest ? new XDomainRequest : new XMLHttpRequest;
if(typeof xmlHttp.withCredentials == undefined) {
alert("您的浏览器不支持跨源的XMLHttpReqeust");
}
}
checkSupport();
function upload(){
xmlHttp.onprogress = function(e){
var radio = e.loaded / e.total;
displayProgress(radio + "% 上传");
}
xmlHttp.onload = function(e){
displayProgress(xmlHttp.responseText);
}
xmlHttp.onerror = function(e){
displayProgress("出错了");
}
var targetLocation = "http://example.com:8080/upload.jsp";
var data = document.getElementById("data").value;
xmlHttp.open("POST", targetLocation, true);
xmlHttp.send(data);
}
function displayProgress(info){
document.getElementById("state").innerHTML = info;
}
</script>
上传消息:
状态:准备
相关推荐
- 轻量级分析利器再升级:解读 DuckDB 1.3.0 新特性
-
DuckDB团队近日正式发布了最新版本——DuckDB1.3.0,代号“Ossivalis”。此次版本以金眼鸭的远古祖先BucephalaOssivalis命名,象征项目在演化和成长过...
- C++跨平台编译的终极奥义:用Docker把环境差异按在地上摩擦
-
"代码在本地跑得飞起,一上服务器就coredump?"——每个C++程序员都经历过的《编译器的复仇》事件!大家好,我是Henry,废话少说,今天来简单谈一下跨平台编译的那些事儿,...
- 全网最全-Version Script以及__asm__((".symver xxx"))使用总结
-
首先提醒一点,一切的前提建立在你的名字必须要mangling,不然无论你写的versionscript还是__asm__都不会起任何效果VersionScript简单用法:这是一个典型例子,这个例...
- Ubuntu 25.04 Beta发布:Linux 6.14内核
-
IT之家3月28日消息,Canonical昨日(3月27日)放出了Beta版Ubuntu25.04系统镜像,代号“PluckyPuffin”,稳定版预估将于2025年...
- 不同平台CRT的区别?什么是UCRT?如何看libc源代码?
-
若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好!CRT运行时库C标准规定例如输入输出函数、字符串函数、内存操作等接口,一般采用C运行时库实现。微软的CRT微软有两套CRT,早期的MS...
- 信创力量,中兴绽放——中兴新支点桌面操作系统安装与使用全攻略
-
原文链接:「链接」Hello,大家好啊,今天给大家带来一篇中兴新支点桌面操作系统安装使用的文章,欢迎大家分享点赞,点个在看和关注吧!中兴新支点桌面操作系统是一款基于Linux内核、面向政企和信创环...
- Linux下安装常用软件都有哪些?做了一个汇总列表,你看还缺啥?
-
1.安装列表MySQL5.7.11Java1.8ApacheMaven3.6+tomcat8.5gitRedisNginxpythondocker2.安装mysql1.拷贝mysql安装文件到...
- 一篇文章解决Linux系统安全问题排查,另配实操环境
-
实操地址:https://www.skillup.host/1/linux/safe/command.md#Linux安全检查排查指南##1.系统账户安全检查###1.1检查异常账户``...
- 程序员必备的学习笔记《TCP/IP详解(一)》
-
为什么会有TCP/IP协议在世界上各地,各种各样的电脑运行着各自不同的操作系统为大家服务,这些电脑在表达同一种信息的时候所使用的方法是千差万别。就好像圣经中上帝打乱了各地人的口音,让他们无法合作一样...
- 《Linux常用命令》(linux的常用命令总结)
-
一、文件与目录操作1.目录导航pwd:显示当前工作目录路径示例:pwd关键词:当前路径、工作目录cd:切换目录示例:cd/home/user#切换到绝对路径cd..#...
- Kubernetes 教程之跟着官方文档从零搭建 K8S
-
前言本文将带领读者一起,参照者Kubernetes官方文档,对其安装部署进行讲解.Kubernetes更新迭代很快,书上、网上等教程可能并不能适用于新版本,但官方文档能.阅读这篇文章你...
- 电脑网卡坏了怎么修复(电脑网卡坏了怎么修复win7系统)
-
当电脑网卡出现故障时,无论是有线网络还是无线网络,都可能无法正常连接。下面从软件、硬件等方面,分步骤为你介绍排查与修复的解决方案。一、初步排查:锁定问题源头检查网络环境将手机、平板等其他设备连接至同一...
- 如何查询电脑/手机的物理地址(如何找手机的物理地址)
-
一、要查询电脑的物理地址(也称为MAC地址),可以按照以下步骤进行操作:1.打开命令提示符(Windows)或终端(Mac):-在Windows上,点击“开始”按钮,搜索“命令提示符”,然后点击打...
- IPv4 无网络访问权限全流程解决方案
-
当设备出现IPv4无网络访问权限问题时,多由网络配置错误、连接故障或服务异常导致。以下提供系统化的排查步骤与解决方案,帮助用户快速定位并修复问题。一、基础故障快速检查1.物理连接确认有线网络:检...
- Python教程(十九):文件操作(python操作文件夹)
-
昨天,我们学习了列表推导式,掌握了Python中最优雅的数据处理方式。今天,我们将学习文件操作—Python中读写文件的基础技能。文件操作是编程中的核心技能,无论是读取配置文件、保存用户数据,还是...
你 发表评论:
欢迎
- 一周热门
-
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
手机如何设置与显示准确时间的详细指南
-
NAS:DS video/DS file/DS photo等群晖移动端APP远程访问的教程
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
一加手机与电脑互传文件的便捷方法FileDash
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
- 最近发表
-
- 轻量级分析利器再升级:解读 DuckDB 1.3.0 新特性
- C++跨平台编译的终极奥义:用Docker把环境差异按在地上摩擦
- 全网最全-Version Script以及__asm__((".symver xxx"))使用总结
- Ubuntu 25.04 Beta发布:Linux 6.14内核
- 不同平台CRT的区别?什么是UCRT?如何看libc源代码?
- 信创力量,中兴绽放——中兴新支点桌面操作系统安装与使用全攻略
- Linux下安装常用软件都有哪些?做了一个汇总列表,你看还缺啥?
- 一篇文章解决Linux系统安全问题排查,另配实操环境
- 程序员必备的学习笔记《TCP/IP详解(一)》
- 《Linux常用命令》(linux的常用命令总结)
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)