以下:

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的更多相关文章

  1. JavaScript权威设计--JavaScript脚本化文档Document与CSS(简要学习笔记十五)

    1.Document与Element和TEXT是Node的子类. Document:树形的根部节点 Element:HTML元素的节点 TEXT:文本节点   >>HtmlElement与 ...

  2. javascript脚本化文档

    1.getElememtById /** * 获取指定id的的元素数组 */ function getElements(/*ids...*/) { var elements = {}; for(var ...

  3. JavaScript 客户端JavaScript之脚本化HTTP(通过XMLHttpRequest)

    XMLHttpRequest对象的设计目的是为了处理由普通文本或XML组成的响应:但是,一个响应也可能是另外一种类型,如果用户代理(UA)支持这种内容类型的话.   大多数浏览的客户端JavaScri ...

  4. JavaScript 客户端JavaScript之 脚本化浏览器窗口

    1.计时器 客户端Javascript以全局函数setTimeOut().clearTimeOut().setInterval().clearInterval()提供这一功能.   前者是从运行的那一 ...

  5. JavaScript 客户端JavaScript之 脚本化文档

    客户端JavaScript的存在把静态HTML转变为交互式的Web应用程序,脚本化Web页面的内容正是JavaScript存在的理由.   一个文档对象模型或者说DOM就是一个API,它定义了如何访问 ...

  6. Javascript学习8 - 脚本化文档(Document对象)

    原文:Javascript学习8 - 脚本化文档(Document对象) 每个Web浏览器窗口(或帧)显示一个HTML文档,表示这个窗口的Window对象有一个document属性,它引用了一个Doc ...

  7. Javascript学习7 - 脚本化浏览器窗口

    原文:Javascript学习7 - 脚本化浏览器窗口 本节讨论了文档对象模型.客户端Javascript下Window中的各项属性,包括计时器.Location对象.Histroy对象.窗口.浏览器 ...

  8. JavaScript权威指南--脚本化CSS

    知识要点 客户端javascript程序员对CSS感兴趣的是因为样式可以通过脚本编程.脚本化css启用了一系列有趣的视觉效果.例如:可以创建动画让文档从右侧“滑入”.创造这些效果的javascript ...

  9. JavaScript权威指南--脚本化文档

    知识要点 脚本化web页面内容是javascript的核心目标. 第13章和14章解释了每一个web浏览器窗口.标签也和框架由一个window对象所示.每个window对象有一个document对象, ...

  10. 深入理解脚本化CSS系列第六篇——脚本化伪元素的6种方法

    × 目录 [1]动态样式 [2]CSS类[3]setAttribute()[4]CSSRule对象添加[5]空样式覆盖[6]CSSRule对象删除 前面的话 我们可以通过计算样式来读取伪元素的样式信息 ...

随机推荐

  1. iOS 获取网络状态

    在iOS开发者,获取网络状态比较常用 -(NSString *)getNetWorkStates{ UIApplication *app = [UIApplication sharedApplicat ...

  2. SharePoint 自定义的列表页面中添加javascript的一个 For循环语句后,该页面就打不开了。

    一个sharepoint 2013的普通的列表的自定义新建页面,我在其中新添加几行javascript代码后页面就打不开了.如图所示: 真是一言不合,友谊的页面说打不开就打不开啊.后来慢慢比对发现是因 ...

  3. 生成的API分析文件太大。我们无法在交付前验证您的API使用信息。这只是通知信息。

    这次使用了APICloud平台来开发移动APP, 发布的时候在api控制台云编译成ipa后,这次使用apple提供的Application Loader工具提交apa文件到iTunes上去,提交结束的 ...

  4. xcode svn commit is not under version control (1) & git commit

    使用Xcode提交一个第三方库时,由于包含资源文件,总是提交不了,提示报错:XXX commit is not under version control (1) 网上查了下,得知 xcode对于sv ...

  5. Linux命令操作

    该命令的功能是将给出的文件或目录拷贝到另一文件或目录中,就如同DOS下的copy命令一样,功能非常强大. 语法: cp [选项] 源文件或目录 目标文件或目录 说明:该命令把指定的源文件复制到目标文件 ...

  6. Ubuntu14.04 Django Mysql安装部署全过程

    Ubuntu14.04 Django Mysql安装部署全过程   一.简要步骤.(阿里云Ubuntu14.04) Python安装 Django Mysql的安装与配置 记录一下我的部署过程,也方便 ...

  7. Linux命令学习总结:reboot命令

    命令简介: 该命令用来重启Linux系统.相当于Windows系统中的restart命令. 命令语法: /sbin/reboot [-n] [-w] [-d] [-f] [-i] 或 reboot [ ...

  8. .net C# SqlHelper for Oracle

    适用于Oracle的sqlhelper 需要使用ODP.Net,引用Oracle.DataAccess.dll 推荐安装ODAC 代码如下: using System; using System.Co ...

  9. MongoDB学习笔记~为IMongoRepository接口更新指定字段

    回到目录 对于MongoDB来说,它的更新建议是对指定字段来说的,即不是把对象里的所有字段都进行update,而是按需去更新,这在性能上是最优的,这当然也是非常容易理解的,我们今天要实现的就是这种按需 ...

  10. java并发编程资料

    并发这玩意很有用,把自己在网上看过觉得总结的很好的资料分享出来.猛击下面的地址查看吧 java并发编程:线程池的使用说明 java并发编程系列文章 Java并发性和多线程专题 并发工具类 Java 7 ...