JavaScript------脚本化HTTP
以下:
1、HTTP:超文本传输协议;
2、Web应用架构:
Ajax (JSONP):请求服务器
Comet: 服务器推送;
3、XMLHttpRequest请求:
var requerst = new XMLHttpRequest(); //实例化
request.open(method,url);//指定请求;
//method:指定HTTP方法或动作;包括:GET POST DELETE HEAD OPTIONS PUT
//url:相对于文档的url或使用绝对路径URL,但是不能跨域;
//第三个是可选参数 默认true表示异步; false表示同步
request.setRequestHeader('Content-Type','application/json;charset=UTF-8');//设置请求头
request.onreadystatechange = function(){
if(request.readyState=== 4 || requset.status === 200){
request.getResponseHeader('Content-Type');//响应类型
request.responseText;//文本形式
request.responseXML;//Document形式
//dosomething 一般传递给回调函数
}
}//响应处理程序 顺序无所谓
request.send(body);//发送请求;此时才会启动网络,但是以上的顺序不能变;
//上传带有文件的表单数据:Content-Type需要使用multipart/form-data来POST提交;
//或(XHR2)使用FormData对象;多次使用append()放入请求参数。支持File和字符串,Blog等;
4、使用<script>发送请求JSONP:
一个根据指定url发送JSONP请求,然后把响应数据传递给回调函数的例子:
//在URL中添加一个名为jsonp的查询参数,用于指定请求的回调函数的名称
function getJSONP(url,callback){
//为请求创建一个唯一的回调函数名称
var cbnum = "cb"+getJSONP.counter++;
var cbname = "getJSONP."+cbnum ;
//使用jsonp作为参数名(有的是callback)
if(url.index('?') === -1)
url+='?jsonp=' + cbname;
else
url+='&jsonp=' + cbname;
//创建script元素用于发送请求
var script = document.createElement('script');
//回调函数执行
getJSONP[cbnum] = function(response){
try{
callback(response);
}
finally{
delete getJSONP[cbnum]; //删除函数
script.parentNode.removeChild(script);//移除元素;
}
}
script.src = url; //立即请求;
document.body.appendChlid(script); //添加到文档
}
getJSONP.counter = 0;
一个通用的例子:
var ax = function(url,method,async,data,contentType,successfn,errorfn){
data = (data==null || data=="" || typeof(data)=="undefined")? {"date": new Date().getTime()} : data;
async = (async==null || async=="" || typeof(async)=="undefined")? true : async;
method = (method==null || method=="" || typeof(method)=="undefined")? 'GET' : method;
var request = new XMLHttpRequest();
request.open(method,url,async);
if(contentType==null || contentType=="" || typeof(contentType)=="undefined"){
//do noting 浏览器会根据参数数据自动设置
}else{
//"application/json;charset=utf-8"
requst.setRequestHeader("Content-Type",contentType);
}
//响应:
request.onreadystatechange = function(){
if(request.readyState === 4 ){
//响应完成
//获取响应类型,服务器端给的
var type = request.getResponseHeader("Content-Type");
var resp = requset.responseText;
if(type.indexOf('xml') !==-1 && requset.responseXML){
resp = requset.responseXML;
}else if(type.indexOf('json') !==-1 ){
resp = JSON.parse(resp);
}else{
//text类型 返回
}
if(request.status === 200){
//而且成功了
successfn(resp);
}else if(request.status > 399){
//但是有错误
errorfn(resp);
}
}
}
//request.overrideMimeType("application/json;charset=utf-8"); //强制响应类型为json
if(contentType.indexOf('json') !==-1 || contentType.indexOf('JSON') !==-1){
request.send(JSON.stringify(data));
}else{
request.send(data);
}
};
可根据实际情况改写;
5、服务端推送的Comet技术:使用EventSource对象,不成熟。。。。。。
JavaScript------脚本化HTTP的更多相关文章
- JavaScript权威设计--JavaScript脚本化文档Document与CSS(简要学习笔记十五)
1.Document与Element和TEXT是Node的子类. Document:树形的根部节点 Element:HTML元素的节点 TEXT:文本节点 >>HtmlElement与 ...
- javascript脚本化文档
1.getElememtById /** * 获取指定id的的元素数组 */ function getElements(/*ids...*/) { var elements = {}; for(var ...
- JavaScript 客户端JavaScript之脚本化HTTP(通过XMLHttpRequest)
XMLHttpRequest对象的设计目的是为了处理由普通文本或XML组成的响应:但是,一个响应也可能是另外一种类型,如果用户代理(UA)支持这种内容类型的话. 大多数浏览的客户端JavaScri ...
- JavaScript 客户端JavaScript之 脚本化浏览器窗口
1.计时器 客户端Javascript以全局函数setTimeOut().clearTimeOut().setInterval().clearInterval()提供这一功能. 前者是从运行的那一 ...
- JavaScript 客户端JavaScript之 脚本化文档
客户端JavaScript的存在把静态HTML转变为交互式的Web应用程序,脚本化Web页面的内容正是JavaScript存在的理由. 一个文档对象模型或者说DOM就是一个API,它定义了如何访问 ...
- Javascript学习8 - 脚本化文档(Document对象)
原文:Javascript学习8 - 脚本化文档(Document对象) 每个Web浏览器窗口(或帧)显示一个HTML文档,表示这个窗口的Window对象有一个document属性,它引用了一个Doc ...
- Javascript学习7 - 脚本化浏览器窗口
原文:Javascript学习7 - 脚本化浏览器窗口 本节讨论了文档对象模型.客户端Javascript下Window中的各项属性,包括计时器.Location对象.Histroy对象.窗口.浏览器 ...
- JavaScript权威指南--脚本化CSS
知识要点 客户端javascript程序员对CSS感兴趣的是因为样式可以通过脚本编程.脚本化css启用了一系列有趣的视觉效果.例如:可以创建动画让文档从右侧“滑入”.创造这些效果的javascript ...
- JavaScript权威指南--脚本化文档
知识要点 脚本化web页面内容是javascript的核心目标. 第13章和14章解释了每一个web浏览器窗口.标签也和框架由一个window对象所示.每个window对象有一个document对象, ...
- 深入理解脚本化CSS系列第六篇——脚本化伪元素的6种方法
× 目录 [1]动态样式 [2]CSS类[3]setAttribute()[4]CSSRule对象添加[5]空样式覆盖[6]CSSRule对象删除 前面的话 我们可以通过计算样式来读取伪元素的样式信息 ...
随机推荐
- JavaScript小细节点罗列
共勉! 属性访问表达式 众所周知,JavaScript为属性的访问定义了两种语法方式: 表达式.标识符 // 表达式(指定对象) 标识符(指定需要访问的属性的名称) 表达式[表达式] //表达式1(指 ...
- .NET破解之百度云盘分享工具(批量)
似曾相识 百度云盘分享工具一款专门用于自动批量分享百度云文件的软件.其原理完全模拟在网页上登录百度云盘,模拟手工点击,将分享的"公共链接"或"私密链接"保存起来 ...
- 关于web软件信息安全问题防护资料的整理 (一)
之前意识到了安全问题的重要性,于是就在网上找了一下安全问题的解决办法(主要是web应用以及政府网站方面的),问了一下同学的公司是怎么保证安全的,跟我说用的是shiro安全机制这个貌似好多公司都在用,网 ...
- 安装Portal for ArcGIS时如何正确配置HTTPS证书
SSL协议位于TCP/IP协议与各种应用层协议之间,为数据通讯提供安全支持.SSL协议可分为两层: SSL记录协议(SSL Record Protocol):它建立在可靠的传输协议(如TCP)之上,为 ...
- iOS模态弹出半透明视图控制器
项目中需要实现点击按钮出现的视图全屏覆盖,呈半透明状态可以看到下面的视图? 解决方案: 绕了很多弯路原来可以使用模态弹出一个视图控制器 在iOS8之后只需要设置一个最新的属性 SecondViewCo ...
- Android Hack1 使用weight属性实现视图的居中显示
本文地址:http://www.cnblogs.com/wuyudong/p/5898403.html,转载请注明源地址. 如果要实现如下图所示的将按钮居中显示,并且占据父视图的一半,无论屏幕是否旋转 ...
- iOS 直播-实现后台录音并推流
iOS 直播-实现后台录音并推流 从一个月前开始开始接收公司的直播类app.到今天为止测试都已接近尾声,但是产品哥哥加了一个要求,就是在app进入后台后也实时保证录音并且推流. 刚听到这个的时候我也是 ...
- [Erlang 0107] Erlang实现文本截断
抽时间处理一下之前积压的一些笔记.前段时间有网友 @稻草人 问字符串截断的问题"各位大侠 erlang截取字符串一般用哪个函数啊",有人支招用string:substr/3, ...
- 47个过程(PMBOK2008)
项目管理过程 知识领域 过程组 含义 之前应完成 之后要进行 制定项目章程 整合 启动 编写一份正式批准项目并授权项目经理使用组织资源的文件的过程 无 制定项目管理计划 制定项目管理计划 整合 规划 ...
- Mysql错误:Ignoring query to other database解决方法
Mysql错误:Ignoring query to other database解决方法 今天登陆mysql show databases出现Ignoring query to other datab ...