ajax-leval升级

window.onload=function(){
        var ok=document.getElementById('ok');
        ok.addEventListener('click',function(ev){
            // console.log(ev)
            var xhr=new XMLHttpRequest();
            xhr.open('get','https://www.easy-mock.com/mock/594fa9d19adc231f3569cdfc/example/proxy');
            // xhr.setRequestHeader("X-HTTP-Method-override",'DELETE')
            // 现在虽然发送的是get请求,但是下面我已经把他覆盖为delete请求了。

            xhr.timeout=3000;
            // 过了这个时间,就自动停止请求,触发timeout事件。


            // xhr.responseType='blob';
            // 表示服务器传回的是二进制对象。

            // 接受
            // var blob=new Blob([res.response],{type:'image/png'})
            xhr.setRequestHeader('Cache-Control','no-cache');
            // 不缓存请求的内容

            // 覆盖请求的http方法:很多主流的web技术只支持GET和post,而且不少的防火墙只允许GET和POST请求通过。


            xhr.onerror=function(e){
                console.log(e);
            }


            xhr.onload=function(e){
                // console.log(e.target.response)
                // 为什么错误也是从这个里面给出的,请求地址的错误是服务器给的么?
            }

            xhr.ontimeout=function(e){
                console.log('请求超时!')
            }
            // 超时

            xhr.onprogress=function(e){
                console.log(e);
                // lengthComputed:可以计算将要返回的数据量true.
                // loaded:当前已载入的数据
                // total:返回可用的数据总量
                if(e.lengthComputable){
                    var precentComplate=Math.floor((e.loaded/e.total)*100)+'%';
                    console.log(precentComplate)
                }
            }


            var headers=xhr.getAllResponseHeaders()
            // console.log(headers)
            // console.log(xhr)


            // 新版本的优点:
            // 1:增加了请求的时限
            // 2:新增了传递表单数据的对象
            // 3:接受二进制数据


            // var formDate=new FormDate();
            // 然后添加信息
            // formDate.append('username','name1');
            // formDate.append('psd',1231231);
            // xhr.send(formDate);
            // 和表单发送是一样的。这个还可以发送file文件。
            // 上传文件
            // 上传进度的显示


            // upload=xhr.upload;
            // upload.onprocess=function(e){
                
            }





            // ======跨域请求

            xhr.send();
        })
    }

1 .xhr是浏览器提供的应用api。这就意味着浏览器会自动帮我们完成所有的底层连接管理,协商管理,http请求格式化。
2 .浏览器根据http的content-type首部来推断适当的数据类型,应用也可以在发起xhr的请求时显示重写数据类型

旧版本写法

xhr.responseType='Blob'

window.onload=function(){
                var XHR=null;  
                if (window.XMLHttpRequest) {  
                    // 非IE内核  
                    XHR = new XMLHttpRequest();  
                } else if (window.ActiveXObject) {  
                    // IE内核,这里早期IE的版本写法不同,具体可以查询下  
                    XHR = new ActiveXObject("Microsoft.XMLHTTP");  
                } else {  
                    XHR = null;  
                }  
                  
                if(XHR){  
                    XHR.open("GET", "https://www.easy-mock.com/mock/594fa9d19adc231f3569cdfc/example/proxy");

                    // XHR.open("GET", "https://www.easy-mock.com/mock/594fa9d19adc231f3569cdfc/example/proxy",true,'adam','secret'); 
                    //是否异步发送,发送给服务器的用户名和密码

                    // XHR.setRequestHeader('Content-Range','365')
                    XHR.onreadystatechange = function () {  
                        // readyState值说明  
                        // 0,初始化,XHR对象已经创建,还未执行open  
                        // 1,载入,已经调用open方法,但是还没发送请求  
                        // 2,载入完成,请求已经发送完成  
                        // 3,交互,可以接收到部分数据  
                  
                        // status值说明  
                        // 200:成功  
                        // 404:没有发现文件、查询或URl  
                        // 500:服务器产生内部错误  
                        if (XHR.readyState == 4 && XHR.status == 200) { 
                            // 前一个代表请求完成,后一个代表请求成功 
                            // 这里可以对返回的内容做处理  
                            // 一般会返回JSON或XML数据格式 
                            // 返回的内容不会直接在页面上显示出来,必须要用js通过XHRd对象接收。
                            console.log(XHR);  
                            // 主动释放,JS本身也会回收的  
                            XHR = null;  
                        }  
                    };  
                    XHR.send();
                    console.log(XHR.getAllResponseHeaders())
                     //获取所有的响应首部 

                     // 以上是老版本的xml对象。具有以下缺点
                     // 1:只能传送文本数据,无法读取和上传二进制文件。
                     // 2:传送和接受数据时,没有进度信息,只能提示有没有完成。
                     // 3:受到“同域限制”,只能像同一域名的服务器请求数据。
                }  

            }

1 .使用promise封装ajax.

ajax优化

1 .交互的及时性可能比后台传输数据更加重要。
2 .如何处理失败的影响
2 .ajax如何改掉用户后退的习惯,让后推按钮失效。history api。在不刷新的条件下,改变浏览器地址显示的url.

异步交互引擎

1 .在客户端嵌入一个中间件,ajax引擎,专门为客户端与服务端之间进行通信服务,这样即使不刷新页面,浏览器也能通过ajax引擎随时与服务器端通信,这样就不需要刷新数据了。
2 .利用隐藏框架实现异步请求。
3 .用《script》标签作为异步交互的工具。
4 .js请求一个函数并执行。服务端定义这个函数并且返回需要的参数信息。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容