ajax入门篇

什么是ajax

AJAX即“Asynchronous JavaScript and XML”(异步的JavaScript与XML技术),指的是一套综合了多项技术的浏览器端网页开发技术。Ajax的概念由杰西·詹姆士·贾瑞特所提出[1]。

传统的Web应用允许用户端填写表单(form),当提交表单时就向网页服务器发送一个请求。服务器接收并处理传来的表单,然后送回一个新的网页,但这个做法浪费了许多带宽,因为在前后两个页面中的大部分HTML码往往是相同的。由于每次应用的沟通都需要向服务器发送请求,应用的回应时间依赖于服务器的回应时间。这导致了用户界面的回应比本机应用慢得多。

与此不同,AJAX应用可以仅向服务器发送并取回必须的数据,并在客户端采用JavaScript处理来自服务器的回应。因为在服务器和浏览器之间交换的数据大量减少,服务器回应更快了。同时,很多的处理工作可以在发出请求的客户端机器上完成,因此Web服务器的负荷也减少了。

类似于DHTML或LAMP,AJAX不是指一种单一的技术,而是有机地利用了一系列相关的技术。虽然其名称包含XML,但实际上数据格式可以由JSON代替,进一步减少数据量,形成所谓的AJAJ。而客户端与服务器也并不需要异步。一些基于AJAX的“派生/合成”式(derivative/composite)的技术也正在出现,如AFLAX

--------来自维基百科

XMLHttpRequest对象

  1. 创建XMLHttpRequest对象

     var httpRequest=new XMLHttpRequest();
    
  2. XMLHttpResquest对象的一些方法

方法或属性作用
open(method,url,async)规定请求的类型、URL 以及是否异步处理请求
请求的类型:GET或者POST
url:请求的文件在文件在服务器上的位置
async:true或者false,代表着异步或者同步
send(String )将请求发送到服务器
String:仅用于 POST 请求
setRequestHeader(header,value)使用POST来提交信息要添加 HTTP 头
header:规定头的名称
value:规定头的值
responseText获得字符串形式的响应数据
responseXML获得 XML 形式的响应数据
onreadystatechange 事件请求状态改变的事件触发器大概指的是 回调函数
readyState存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。
status200: “OK” ,404:未找到页面

readyState

  1. 请求未初始化
  2. 服务器连接已建立
  3. 请求已接收
  4. 请求处理中
  5. 请求已完成,且响应已就绪

随手案例

目录
在这里插入图片描述
index.jsp代码

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html><head><title>ajax</title></head><body>用户名:<input type="text" id="username"><input type="submit" value="验证用户名" onclick="checkUsername()"><div id="B"></div></body>
<script type="text/javascript">var httpRequest;function checkUsername() {if (window.XMLHttpRequest) {httpRequest = new XMLHttpRequest();}var name = document.getElementById("username").value;httpRequest.onreadystatechange = function () {if (httpRequest.readyState == 4 && httpRequest.status == 200) {var text = httpRequest.responseText;var div = document.getElementById("B");if(name==text){div.innerText = text;}else {div.innerText="用户名有误";}}//指定回调函数}httpRequest.open("post", "http://localhost:8080/ajaxtest_war_exploded//test.txt", true);httpRequest.setRequestHeader("Content-type", "application/x-www-form-urlencoded");//请求头httpRequest.send("username=" + name);}</script>
</html>

text.txt文件
在这里插入图片描述

演示结果

在这里插入图片描述

局部交互数据,不刷新界面。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/548110.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

BJRangeSliderWithProgress

2019独角兽企业重金招聘Python工程师标准>>> BJRangeSliderWithProgress 是一个带范围选择的进度条&#xff0c;我用它来做录音的进度指示&#xff0c;并可在选择的范围内进行回放。 转载:http://www.adobex.com/ios/source/details/00000865.htm 转载于:https://my…

servlet+JQuery ajax以json的形式的验证表单小实例

JQuery $.ajax() $.ajax({type: POST, //请求方式 一般是get&#xff0c;posturl: url , // 这是必需的&#xff0c;规定把请求发送到哪个 URLdata: data , //这个是可选。映射或字符串值。规定连同请求发送到服务器的数据。java中用request.getPara…

JSONObject与GSON的一些常用的方法的使用

通过学习ajax然后接触了Json最后通过json接触到了JSONObject和Google的GSON&#xff0c;下面来一起看看JSONObject和GSON吧。 先附上依赖 //JSONObject依赖<dependency><groupId>net.sf.json-lib</groupId><artifactId>json-lib</artifactId>&…

tomcat 启用NIO

从Tomcat6.0以后, Java开发者很容易就可以是用NIO的技术来提升tomcat的并发处理能力。 <Connector port"8080" protocol"HTTP/1.1"connectionTimeout"20000"redirectPort"8443" /> 修改成&#xff1a; <Connector port"…

Mybatis(2)---多表查询

首先数据库表展示 User表 Role角色表 关联User表与Role表关系的user_role表 因为是要串联关系所以需要设置外键&#xff0c;以下是外键展示 工程目录展示 pom.xml依赖配置 <dependencies><dependency><groupId>junit</groupId><artifactId>…

ORA-29702:error occurred in Cluster Group Service operation错误解决

ORA-29702:error occurred in Cluster Group Service operation错误解决作者: djb1008(http://djb1008.itpub.net)发表于: 2011.05.10 15:43分类: Oracle 出处: http://djb1008.itpub.net/post/42280/517654--------------------------------------------------------------- 一…

JavaScript复习使用定时器的简易式诸葛大力轮播图

先上效果图 很简单的代码 先创建个文件夹保存成果的照片&#xff0c;然后通过更改src来用定时器循环这些照片 <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><meta name"viewport" content"…

搜索分布式

http://blog.sina.com.cn/s/blog_539d361e0100xcy9.html http://stackoverflow.com/questions/6923071/lucene-is-it-the-right-answer-for-huge-index http://www.hpl.hp.com/techreports/2008/HPL-2008-64.html http://www.gossamer-threads.com/lists/lucene/general/58087

复习---使用基础语法实现栈及迭代

上图是最最基本的结构&#xff0c;这次我采用数组实现栈。使用数组实现栈&#xff0c;由于java的数组是固定长度的。所以我需要写一个增加长度的方法。然后就是迭代的问题了。使用数组实现栈的话&#xff0c;我们需要写一个迭代器。不过这个迭代器非常容易实现&#xff0c;只需…

同一个闭区间上有界变差函数的和与积都是有界变差函数

设$f,g$是$[a,b]$上的[有界变差函数],则$fg$也是$[a,b]$上的有界变差函数. 证明&#xff1a;设$P\{x_0,\cdots,x_n\}$是对$[a,b]$的任意分割.由于$f$是$[a,b]$上的有界变差函数&#xff0c;因此$$\sum_{i0}^{n-1}|f(x_{i1})-f(x_i)|<M_1$$且$$\sum_{i0}^{n-1}|g(x_{i1})-g(x…

复习----使用链表实现栈(后进先出)及迭代

使用链表进行模拟栈比用数组好用&#xff0c;考虑的要素也少还方便。 链表结构 private class Node{//链表结构Item item;Node next;}迭代器 private class Iterator implements java.util.Iterator<Item>{//迭代器private Node pfirst;Overridepublic boolean hasNex…

复习----使用链表实现队列(先进先出)及迭代

实现队列比实现栈的会多一点复杂&#xff0c;需要两个标记&#xff0c;first表示队头&#xff0c;last表示队尾。 链表结构 private class Node{Item item;Node next;}迭代器 与实现栈的迭代器一模一样 private class Iterator implements java.util.Iterator<Item>{p…

感冒不吃药

感冒药既治不好感冒也不能加速痊愈&#xff0c;只是缓解症状而已 有两百多种不同的病毒都可以引起普通感冒。还有一种感冒叫流感&#xff0c;比起普通感冒来更严重&#xff0c;可能会多高热、恶心等症状。不过流感是由特定的流感病毒引发&#xff0c;可以通过打疫苗来预防。不管…

复习--linux目录及文件操作

文件及目录的一些操作 你可以使用 man [命令]来查看各个命令的使用文档&#xff0c;如 &#xff1a;man mv 目录查看 目录查看 ls -[alh] [文件或目录名称] 不加 [文件或目录名称]的话默认是当前目录路径 绝对路径 从根目录开始写起&#xff0c;用 /表示根目录 相对路径 ./表示…

RedHat Enterprise AS4安装步骤

//因RDMS使用新版本CentOS6.2 有问题 &#xff0c; 没办法只有装低版本操作系统 &#xff01; 概述 Redhat公司的Enterprise Linux AS系列 &#xff08;以下简称AS系列&#xff09;&#xff0c;其中Fedora Core 是符合GPL协议的免费版本&#xff0c;使用范围广泛。AS是高性能的…

贪心---leetcode-376摆动序列

题目 如果连续数字之间的差严格地在正数和负数之间交替&#xff0c;则数字序列称为摆动序列。第一个差&#xff08;如果存在的话&#xff09;可能是正数或负数。少于两个元素的序列也是摆动序列。 例如&#xff0c; [1,7,4,9,2,5] 是一个摆动序列&#xff0c;因为差值 (6,-3,…

[转]我们为什么需要工作流

本文转自&#xff1a;http://www.cnblogs.com/foundation/archive/2009/01/12/1374163.html 这是我的"基于WF设计业务流程平台"的题外篇 以下是这系列的文章列表,写的很痛苦,但我会继续写下去 基于WF设计业务流程平台-架构 基于WF设计业务流程平台-权限体系 基于WF设…

贪心---移掉K位数字

题目 给定一个以字符串表示的非负整数 num&#xff0c;移除这个数中的 k 位数字&#xff0c;使得剩下的数字最小。 注意: num 的长度小于 10002 且 ≥ k。num 不会包含任何前导零。 示例 1 : 输入: num “1432219”, k 3 输出: “1219” 解释: 移除掉三个数字 4, 3, 和 2 形…

应用层——使用 Socket 通信实现 FTP 客户端程序

转自&#xff1a;http://blog.csdn.net/yixijide/article/details/8280263 简介&#xff1a; FTP 客户端如 FlashFXP&#xff0c;File Zilla 被广泛应用&#xff0c;原理上都是用底层的 Socket 来实现。FTP 客户端与服务器端进行数据交换必须建立两个套接字&#xff0c;一个作为…

Java-IO-对接流

不管是什么文件都可以用字节来表示&#xff0c;下面的例子是将图片解码成字节&#xff0c;然后再编码成图片。 过程 首先将图片解码&#xff0c;我们需要用文件字节输入流&#xff1a;FIleInputStream 用FIleInputStream可以将图片储存到字节数组中&#xff0c;我们通过read(…