原生Javascript封装的一个AJAX函数分享


Posted in Javascript onOctober 11, 2014

最近的工作中涉及到大量的ajax操作,本来该后台做的事也要我来做了.而现在使用的ajax函数是一个后台人员封装的—-但他又是基于jquery的ajax,所以离开了jquery这个函数就毫无作用了.而且我觉得,jquery的ajax方法是很完善的了,可以直接用,如果都有jquery了,那么他的ajax就不用白不用了.我缺少的是一个能在没有jquery的情况下使用的ajax方法.

所以我也花一天时间写了一个,参数与调用方法类似于jquery的ajax.就叫xhr吧,因为xhr=XMLHttpRequest.

/*

* Name: xhr,AJAX封装函数

* Description: 一个ajax调用封装类,仿jquery的ajax调用方式

* Author:十年灯

*/

var xhr = function () {

    var 

    ajax = function  () {

        return ('XMLHttpRequest' in window) ? function  () {

                return new XMLHttpRequest();

            } : function  () {

            return new ActiveXObject("Microsoft.XMLHTTP");

        }

    }(),

    formatData= function (fd) {

        var res = '';

        for(var f in fd) {

            res += f+'='+fd[f]+'&';

        }

        return res.slice(0,-1);

    },

    AJAX = function(ops) {

        var     

        root = this,

        req = ajax();
        root.url = ops.url;

        root.type = ops.type || 'responseText';

        root.method = ops.method || 'GET';

        root.async = ops.async || true;     

        root.data = ops.data || {};

        root.complete = ops.complete || function  () {};

        root.success = ops.success || function(){};

        root.error =  ops.error || function (s) { alert(root.url+'->status:'+s+'error!')};

        root.abort = req.abort;

        root.setData = function  (data) {

            for(var d in data) {

                root.data[d] = data[d];

            }

        }

        root.send = function  () {

            var datastring = formatData(root.data),

            sendstring,get = false,

            async = root.async,

            complete = root.complete,

            method = root.method,

            type=root.type;

            if(method === 'GET') {

                root.url+='?'+datastring;

                get = true;

            }

            req.open(method,root.url,async);

            if(!get) {

                req.setRequestHeader("Content-type","application/x-www-form-urlencoded");

                sendstring = datastring;

            }      
            //在send之前重置onreadystatechange方法,否则会出现新的同步请求会执行两次成功回调(chrome等在同步请求时也会执行onreadystatechange)

            req.onreadystatechange = async ? function  () {

                // console.log('async true');

                if (req.readyState ==4){

                    complete();

                    if(req.status == 200) {

                        root.success(req[type]);

                    } else {

                        root.error(req.status);

                    }                   

                }

            } : null;

            req.send(sendstring);

            if(!async) {

                //console.log('async false');

                complete();

                root.success(req[type]);

            }

        }

        root.url && root.send();        

    };

    return function(ops) {return new AJAX(ops);}    

}();

参数说明:

1.url:请求地址.可以不填,请求就不会发起,但如果不填又强行send,出了错不怪我
2.method: ‘GET'或'POST',全大写,默认GET
3.data: 要附带发送的数据,格式是一个object
4.async: 是否异步,默认true
5.type: 返回的数据类型,只有responseText或responseXML,默认responseText
6.complete: 请求完成时执行的函数
7.success: 请求成功时执行的函数
8.error: 请求失败时执行的函数

注:其中的type参数,并没有jquery的dataType那么丰富,只有原生AJAX有的responseText或responseXML.要是返回的是json数据,你需要在success函数中自己处理一下把text转成json.

函数说明:

一个实例化的xhr对象有两个函数可使用,一个是send,调用方法是:xhr.send(),无参数,其作用是发起请求过程.如果初始化时没有url,则不会执行send方法,这样你就可以在后面再加入url,并手动发起send—-如果send的时候没有url,那么请求会失败并且我没有处理这个错误,出了错只有你自己找了.

另一个方法是setData,调用方法是xhr.setData(data_obj),其参数是一个object. setData方法的作用是局部替换xhr的data属性里的值,比如xhr.data中已有一个page:1,你可以用xhr.setData({page:2})来更新他的值,而不影响data中已存在的其他属性值.

调用方法:

var a1 = xhr({

        url:'2.php',

        data:{

            'username':'lix',

            'password':'123456',

            'gender':'male',

            'interset':'play'

        },

        async:false,

        method:'GET',

        success: function  (data) {

            var obj = JSON.parse(data);

            //....

        }

    });

注:不用写new

特色介绍:

经过这段时间的项目经验,我发现一个ajax类应该具有一个很常见的特色:便于重复发起请求.比如项目中我写分页ajax的时候,每次翻页都要发送请求,但发送的数据中除了当前页码和每页条数,其他的都是不会改变的.如果多次这样的请求,都要重复定义那些不变的参数,无疑是种资源浪费.

所以这个xhr函数,就已经考虑了这个功能.还是拿分页的例子来说,我们可以在页面加载完成的时候就初始化一个xhr对象,保存为变量a1,当发起翻页请求时,其他的什么参数都没变,但pageNumber变了,此时就可以调用xhr的setData方法,把pageNumber改掉.

a1.setData({pageNumber:2});

注:setData的参数也是一个object.

当然,你也可以把data全盘替换:

a1.data = {…};

不只是data,你可以对a1这个已经实例化的xhr对象进行更多的更改,比如换掉url,换掉success函数,GET换成POST,同步换成异步…换完之后,再调用a1.send()方法,他就会按你的设置再次发起请求了.

当然,如果是完全不相关的另一个ajax请求,就没有必要硬要用这个现成的a1了.我们可以再实例化一个xhr,叫a2什么的.

如果你对xhr这个名字不满意,那就只有自己改掉了.

另外提供压缩加密版.未压缩版去掉注释大概2kb,压缩版1.00kb.

var xhr=function(){var e=function(){return"XMLHttpRequest"in window?function(){return new XMLHttpRequest}:function(){return new ActiveXObject("Microsoft.XMLHTTP")}}(),t=function(e){var t="";for(var n in e){t+=n+"="+e[n]+"&"}return t.slice(0,-1)},n=function(n){var r=this,i=e();r.url=n.url;r.type=n.type||"responseText";r.method=n.method||"GET";r.async=n.async||true;r.data=n.data||{};r.complete=n.complete||function(){};r.success=n.success||function(){};r.error=n.error||function(e){alert(r.url+"->status:"+e+"error!")};r.abort=i.abort;r.setData=function(e){for(var t in e){r.data[t]=e[t]}};r.send=function(){var e=t(r.data),n,s=false,o=r.async,u=r.complete,a=r.method,f=r.type;if(a==="GET"){r.url+="?"+e;s=true}i.open(a,r.url,o);if(!s){i.setRequestHeader("Content-type","application/x-www-form-urlencoded");n=e}i.onreadystatechange=o?function(){if(i.readyState==4){u();if(i.status==200){r.success(i[f])}else{r.error(i.status)}}}:null;i.send(n);if(!o){u();r.success(i[f])}};r.url&&r.send()};return function(e){return new n(e)}}()

xhr肯定有不完善的地方,以后使用中如果发现了,我会及时修正的.如果你用得不爽或发现不足,也请不吝提出改进意见.

Javascript 相关文章推荐
地址栏上的一段语句,改变页面的风格。(教程)
Apr 02 Javascript
CSS+Jquery实现页面圆角框方法大全
Dec 24 Javascript
jQuery实用基础超详细介绍
Apr 11 Javascript
jquery cookie实现的简单换肤功能适合小网站
Aug 25 Javascript
javascript history对象(历史记录)使用方法(实现浏览器前进后退)
Jan 07 Javascript
Javascript 按位左移运算符使用介绍(
Feb 04 Javascript
jQuery对指定元素中指定字符串进行替换的方法
Mar 17 Javascript
jquery实现点击向下展开菜单项(伸缩导航)效果
Aug 22 Javascript
jquery实现网页的页面平滑滚动效果代码
Nov 02 Javascript
Bootstrap轮播插件中图片变形的终极解决方案 使用jqthumb.js
Jul 10 Javascript
微信小程序整合使用富文本编辑器的方法详解
Apr 25 Javascript
在Node.js中将SVG图像转换为PNG,JPEG,TIFF,WEBP和HEIF格式的方法
Aug 22 Javascript
探讨js字符串数组拼接的性能问题
Oct 11 #Javascript
分享20款美化网站的 jQuery Lightbox 灯箱插件
Oct 10 #Javascript
Jquery $.getJSON 在IE下的缓存问题解决方法
Oct 10 #Javascript
js点击button按钮跳转到另一个新页面
Oct 10 #Javascript
jQuery获取iframe的document对象的方法
Oct 10 #Javascript
jquery实现多行文字图片滚动效果示例代码
Oct 10 #Javascript
一个js过滤空格的小函数
Oct 10 #Javascript
You might like
YB217、YB235、YB400浅听
2021/03/02 无线电
php实现首页链接查询 友情链接检查的代码
2010/01/05 PHP
php在程序中将网页生成word文档并提供下载的代码
2012/10/09 PHP
一个好用的PHP验证码类实例分享
2013/12/27 PHP
PHP图片处理之图片背景、画布操作
2014/11/19 PHP
php查找字符串出现次数的方法
2014/12/01 PHP
php中实现用数组妩媚地生成要执行的sql语句
2015/07/10 PHP
AES加解密在php接口请求过程中的应用示例
2016/10/26 PHP
php使用curl代理实现抓取数据的方法
2017/02/03 PHP
php微信公众号开发之校园图书馆
2018/10/20 PHP
Laravel框架实现的批量删除功能示例
2019/01/16 PHP
分享几种好用的PHP自定义加密函数(可逆/不可逆)
2020/09/15 PHP
jQuery DOM操作小结与实例
2010/01/07 Javascript
JavaScript代码简单实现求杨辉三角给定行的最大值
2013/10/29 Javascript
jquery基础教程之数组使用详解
2014/03/10 Javascript
angular简介和其特点介绍
2015/01/29 Javascript
jQuery on()方法使用技巧详解
2015/04/16 Javascript
js实现滑动触屏事件监听的方法
2015/05/05 Javascript
jquery插件bootstrapValidator表单验证详解
2016/12/15 Javascript
BootStrapValidator初使用教程详解
2017/02/10 Javascript
jQuery实现一个简单的轮播图
2017/02/19 Javascript
vue相关配置文件详解及多环境配置详细步骤
2020/05/19 Javascript
Python性能提升之延迟初始化
2016/12/04 Python
Python使用django框架实现多人在线匿名聊天的小程序
2017/11/29 Python
Python+Turtle动态绘制一棵树实例分享
2018/01/16 Python
python开启摄像头以及深度学习实现目标检测方法
2018/08/03 Python
python+selenium 定位到元素,无法点击的解决方法
2019/01/30 Python
python利用Excel读取和存储测试数据完成接口自动化教程
2020/04/30 Python
CSS3 3D旋转rotate效果实例介绍
2016/05/03 HTML / CSS
北美主要的汽车零部件零售商:AutoShack.com
2019/02/23 全球购物
学校采购员岗位职责
2014/01/02 职场文书
实习公司领导推荐函
2014/05/21 职场文书
2014年城市管理工作总结
2014/12/02 职场文书
迎新生欢迎词2015
2015/07/16 职场文书
祝福语集锦:送给毕业同学祝福语
2019/11/21 职场文书
vue使用watch监听属性变化
2022/04/30 Vue.js