[妙味Ajax]第一课:原理和封装
知识点总结:
ajax是异步的javascrip和xml,用异步的形式去操作xml
访问的是服务端,即https://127.0.0.1/ 或者 https://localhost
1、创建一个ajax对象(=打开浏览器)
存在兼容性方面的问题
var xhr = new XMLHttpRequest();
var xhr = new ActiveXObject('Microsoft.XMLHTTP); IE6
方法一:
var xhr = null;
if(window.XMLHttpRequest){
xhr = new XMLHttpRequest();
} else {
xhr = new ActiveXObject('Microsoft.XMLHTTP');
} 方法二:
var xhr = null;
try{
//如果出错,则执行catch下的,并传入错误参数e
xhr = new XMLHttpRequest();
// throw new Error('错误'),为手动报错,使用较少
} catch(e) {
xhr = new ActiveXObject('Microsoft.XMLHTTP'); //IE6
}
2、open方法(=在地址栏输入地址)
xhr.open('post','1.txt',true)
参数:
1、打开方式
get :
通过url?名称=值&名称=值的方式进行传递,即url?username=joya&sex=female
url长度有限制,因此对传输的数据有大小限制
安全性问题,因为在url?后面,所以数据会被浏览器缓存起来,可以通过历史记录读取到数据
post :
通过表头的形式来传递,chrome需要审查元素-->network下查看,格式也是 => 名称=值&名称=值
长度没有限制
在php中,post方式可以用$_POST[]获取,get方式可以用$_GET[]获取,两种方式都可以获取,使用$_REQUEST[]
2、地址URL
3、是否同步
true :异步,非阻塞(一般使用此方法),setTimeout也是异步的
false :同步,阻塞,前面的代码后面需要用到,此时使用同步方式
3、发送请求(=回车)
// 如果要向表单post那样提交,需要使用setRequestHeader()添加HTTP表头,然后在 send() 方法中规定您希望发送的数据
// xhr.setRequestHeader('Content-type','application/x-www-form-urlencoded');
xhr.send();
4、等待服务器返回内容(=等待浏览器显示数据)
onreadystatechange 当readyState改变的时候触发
readyState 请求状态(ajax的工作状态):
0:(未初始化)还没有调用open()方法
1:(载入)已调用send()方法,正在发送请求
2:(载入完成)send()方法完成,已收到全部响应内容
3:(解析)正在解析内容
4:(完成)响应内容解析完成,可以在客户端调用
responseText :ajax请求返回的内容被存放在这个属性下
xhr.onreadystatechange = function(){
if (xhr.readyState == 4) {
//status进行查错处理,即查服务器状态,为http状态码
if (xhr.status == 200 ) {
alert(xhr.responseText);
} else {
alert('出错了,error:'+xhr.status);
}
}
}
reposeText是string类型,如果数据是类似json和数组的样子,则需要转换将string-->json/数组
alert(JSON) //注意:全是大写,ie7和ie6不支持JSON这个对象,解决方法:访问json官网json.org,下载javscript-->json2.js,把json2.js链接到页面
json2.js提供两个方法:
stringify:json/数组-->string,使用JSON.stringify()
parse:string-->json/数组,使用JSON.parse(),如是json,名称需要用“”括起来(严格模式),即json = '{"age",10}'
post和get需要的注意事项
get:
1 、在IE中有缓存问题,因此需要在后面加上一个随机数/时间戳,即Math.random()/new Date().getTime()
例如:'test.php?username=joya&age=10&' + newDate().getTime(),注:时间戳前面必须加上&
2、如果有中文,存在编码问题,需要转码,即:encodeURI()
例如:'test.php?username='+encodeURI('叶子')+'&age=10&' + newDate().getTime()
post:
1、不存在缓存和编码问题
2、发送请求头,申请发送的数据类型
xhr.setRequestHeader('Content-type','application/x-www-form-urlencoded')
数据是放在send()中作为参数传递,即:send('username=joya&age=10')
[妙味Ajax]第一课:原理和封装的更多相关文章
- [妙味Ajax]第二课:实例:留言板、瀑布流
知识点总结 瀑布流原理(固定布局) 总宽度大小固定 每列宽度固定,比如LI,高度自动计算,每列使用float:left来布局 计算最短的一列,将Div插到最短的一列处(li里面包div)(getSho ...
- [妙味DOM]第一课:DOM基础概念、操作
知识点总结 childNodes.children子节点列表集合.nodeType节点类型.nodeName.nodeValue.attributes属性列表集合 childNodes和childre ...
- [妙味Ajax]第三课:AJAX跨域解决方案:JSONP
知识点总结: JSONP(JSON with Padding): 1.script标签 2.用script标签加载资源是没有跨域问题的 在资源加载进来之前定义好一个函数,这个函数接收一个参数(数据), ...
- [妙味 DOM] 第二课:DOM、BOM相关方法及属性
知识点总结 获取样式.增加样式.删除样式函数的封装 表格 tHead tBodies tFoot rows 行 cells 列 表单 表单可以通过name来获取元素:表单.name值 onchange ...
- Ajax第一课
<script language="javascript"></script> Javascript 函数创建 function 函数名(){ ...
- 妙味课堂——HTML+CSS(第一课)
一句话,还记忆不如烂笔头,何况还这么笨,记下笔记,也是记录这一路学习的过程. 妙味课堂第一课并未一味地先讲HTML,而是穿插着CSS讲解,这一点不同于一些其他视频,这一点挺特别的!所以这一课涉及到HT ...
- 妙味课堂:JavaScript初级--第11课:字符串、查找高亮显示
1.数字字母 Unicode 编码 <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content- ...
- 妙味课堂——HTML+CSS(第四课)(二)
单开一篇来讲一个大点的话题——清浮动 来看下例: <!DOCTYPE html> <html> <head> <meta charset="U ...
- 妙味课堂——JavaScript基础课程笔记
集中时间把秒微课堂JS的基础课程看完,并且认真完成了课后练习.感觉在JS方面的技能算是入了个门了.课后练习的作业完成的代码我都汇总在了这里.至于视频课的学习笔记,则记录如下. 第01课JS入门基础_热 ...
随机推荐
- HTTP协议----ETag
Etag是URL的Entity Tag,用于标示URL对象是否改变,区分不同语言和Session等等.具体内部含义是服务器控制的,就像Cookie那样. 服务器首先产生ETag,服务器可在稍后使用它来 ...
- hdu1038
#include <stdio.h> #define P 3.1415927 #define toFeet(x) x/12.0 #define toMiles(x) x/5280.0 in ...
- ListView添加节点
ListView插入节点的流程 当ListView控件的样式被设置成report时,ListView控件实际上是分为两个部分, 一部分是Column, 这个部分是用来显示ListView的每一列的标题 ...
- Linux下的暴力密码在线破解工具Hydra安装及其组件安装-使用
Linux下的暴力密码在线破解工具Hydra安装及其组件安装-使用 hydra可以破解: http://www.thc.org/thc-hydra,可支持AFP, Cisco AAA, Cisco a ...
- OSI模型第二层数据链路层-STP协议
1.stp协议的由来. 在二层网络中,交换机起到了很重要的作用,如果有一台交换机出现故障会影响网络的使用,为了避免存在单点故障,在实际的二层链路中会采用链路冗余,也就是采用交换设备之间多条联络连接,即 ...
- 制作Ubuntu14.04的Openstack镜像
下载好Ubuntu官方镜像安装文件:不要使用desktop版,在virtualbox和vm上都安装报错,因为不需要桌面,所有没去管了. 第一步.准备好如下文件: 1.ubuntu-14.04.4-se ...
- CodeForces 681D Gifts by the List
$dfs$,后续遍历. 如果某个节点$a[i]=i$,那么$i$的后继的$a[i]$都要指向$i$,直到出现新的后继$j$,$a[j]=j$.利用这个可以判断是否有解. 如果有解的话,那么只要输出后序 ...
- IOS常遇问题个人收藏网址指南
代码适配Masonry使用的详细介绍: http://blog.csdn.net/majiakun1/article/details/51160339 Masonry使用注意篇: http://www ...
- Python学习笔记——基础篇【第二周】——解释器、字符串、列表、字典、主文件判断、对象
目录 1.Python介绍 2.Python编码 3.接受执行传参 4.基本数据类型常用方法 5.Python主文件判断 6.一切事物都是对象 7. int内部功能介绍 8.float和long内 ...
- [阿当视频]WEB组件学习笔记
— 视频看完了,自定义事件还不懂,等完全懂了再更新并完成整篇案例 1. JS分层和组件的种类浏览器底层包括HTML CSS JS(DOM/BOM/Style/Canvas 2D/WebGl/SVG) ...