Ajax棵
ajax
1.什么是ajax?(异步请求,局部刷新)
ajax是一个改善用户体验的技术,实质上是利用浏览器端ajax对象()向服务器发送异步(ajax对象在向服务器发送请求的时候,用户可以继续其他操作)请求,服务器返回的text或者xml类型的数据,浏览器根据返回的数据,对页面进行局部刷新。
在整个过程中,不会中断用户的操作,体验度好。
2.如何获取ajax对象?
非IE new XMLHttpRequest();
IE new ActiveXObject("Microsoft.XMLHttp");
3.ajax向服务器发送请求
(asynchronous JavaScript and xml)
-----发送get请求---------
1)获取ajax对象
var xhr=getXhr();
2)注册监听器
xhr.onreadystatechange
3)初始化
xhr.open('get','CheckUname.do',true);
'get':请求类型、
'checkUname.do':请求地址
'true':发送异步请求
'false';发送同步请求
ajax向服务器发送请求,在服务器返回响应之前,用户必须等待,如果服务器响应的时间过长,页面出现锁死状态,用户体验度不好
4)真正发送请求
xhr.send(null);
*ajax对象的重要属性:
1)onreadystatechange:注册一个监听器(绑定一个事件函数)
2)readyState:返回对象与服务器的状态
返回一个值,含义如下:
0:未初始化,对象已经建立,但是还没有调用open方法
1:初始化,对象已经建立,但是没有调用send方法
2:发送数据,send方法已调用
3:数据传送中,服务器已经接受了部分数据
4:响应结束,浏览器接受了所有数据
3)responseText:获取服务器返回的文本
4)responseXML:获取服务器返回的XML dom对象
5)status:获取状态码
200 405 404
若ajax发送的是get请求,IE浏览器存在以下问题
1)如果请求地址没有发生改变,那么IE不会真正向服务器发送请求,返回的是上一次请求服务器的数据(被IE缓存了)
解决方法一:给地址后面加时间戳
var url="checkUname.do?uname="+$("[name=uname]").val()+"&"+new Date().getTime();
xhr.open('get',url,true);
2)参数中文乱码问题
解决方法:
step1.Tomcat/conf/server.xml中编码格式是UTF-8
step2.encodeURI(url) 将地址中的中文以utf-8的格式转成对应的字节
解决方法二:发送post请求
----发送post请求---
1)获取ajax对象
2)同(get)
3)初始化
xhr.open('post','checkUname.do',true);
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); (这句话不能省)
4)真正发送请求
xhr.send("uname="+uname);
练习:省市联动
Ajax棵的更多相关文章
- Hawk 3.1 动态页面,ajax,瀑布流
不少朋友反映,Hawk的手气不错,好像没法处理动态页面.其实很容易,比其他软件都容易,让我慢慢道来. 1. 什么是动态页面 很多网站,在刷新的时候会返回页面的全部内容,但实际上只需要更新一部分,这样可 ...
- 异步请求Ajax
AJAX:Asynchronous JS And XML,包括HTML.CSS.JS.DOM.XML.JSON等,客户端技术范畴.主要目标:发起异步请求/响应,实现页面内容的局部刷新,提高浏览体验:实 ...
- 原生态AJAX详解和jquery对AJAX的封装
AJAX: A :Asynchronous [eI`sinkrenes] 异步 J :JavaScript JavaScript脚本语言 A: And X :XML 可扩展标记语言 AJAX现在 ...
- jquery中ajax的使用
Java软件开发中,后台中我们可以通过各种框架,像SSH等进行对代码的封装,方便我们对Java代码的编写,例如,Struts,SpringMVC对从前台到action的流程进行封装控制,使我们只需要进 ...
- AJAX文档
AJAX 文档 AJAX开发简略.................................................................................... ...
- ajax异步请求不能刷新数据的问题
搞了两三天的问题,今天解决了.总结下: function reportGrpChange(cuid, title){ document.getElementById('reportFrameDiv') ...
- 哈佛大学构建动态网站--第七讲ajax
Ajax ajax举例: DOM的结构 通过js来修改html页面. Ajax的含义: return false的用途 跨浏览器的ajax 为什么不直接从yahoo获得数据呢? XMLHttpRequ ...
- Ajax获取数据的几种格式和解析方式
一.什么是ajax AJAX的全称是Asynchronous JavaScript and XML(是异步的 javascript 和 XML). ajax不是新的编程语言,而是一种使用现有标准的 ...
- 关于AJAX异步请求的那些事儿(2)
1.使用AJAX发起GET请求消息 xhr.open("GET","XX.PHP?K1=V1$K2=V2",true); xhr.send(null); 2.使 ...
随机推荐
- html5新增标签/删除标签
闲聊: 最近小颖工作稍微比较轻松,没事就看看慕课,看了看:HTML5之元素与标签结构,里面简单讲解了下HTML5的一些新特性,小颖之前没写过HTML5的页面,所以就当写笔记将那些新的特性整理出来,也方 ...
- HP P2xxx/MSA SMI-S Provider
HP P2xxx/MSA SMI-S Provider The HP MSA provider must be enabled before it can be monitored. For more ...
- OC开发_Storyboard——MapKit
一.Core Location 1.基本对象 @propertys: coordinate, altitude, horizontal/verticalAccuracy, timestamp, sp ...
- vue--使用定时器的问题
https://blog.csdn.net/ywl570717586/article/details/79963162
- Jmeter与Jenkins结合进行Web接口测试
纯通过Jmeter的界面进行Web的接口测试,效率低下.为此将Jmeter的接口测试与Jenkins联合,实现持续集成.配置完成后,只需修改运行的Jmeter脚本即可,运行结束后测试结果发送到指定邮箱 ...
- mvc 实现超时弹窗后跳转
为了实现保持登录状态,可以用cookie来解决这一问题 假设过期时间为30分钟,校验发生在服务器,借助过滤器,可以这样写 public class PowerFilter : AuthorizeAtt ...
- postgresql----数组类型和函数
postgresql支持数组类型,可以是基本类型,也可以是用户自定义的类型.日常中使用数组类型的机会不多,但还是可以了解一下.不像C或JAVA高级语言的数组下标从0开始,postgresql数组下标从 ...
- FZU 2252 Yu-Gi-Oh!(枚举+贪心)
Problem 2252 Yu-Gi-Oh! Accept: 105 Submit: 628 Time Limit: 1000 mSec Memory Limit : 32768 KB ...
- ubuntu16.04下安装artoolkit5
目前对AR技术的常见理解就是CV(Computer Vision)+CG(Computer Graphic).CV的方法很多,简单些比如FREAK+ICP(ARToolKit中的NFT),复杂些就是S ...
- HDU 4578 - Transformation - [加强版线段树]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4578 Problem Description Yuanfang is puzzled with the ...