原生封装Ajax与jQuery实现Ajax

本文详细介绍了原生封装Ajax的方法及与jQuery封装的对比,通过实例演示了创建XMLHttpRequest对象、发送请求、注册回调函数及服务器响应的全过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原生封装Ajax

对比使用JQuery直接封装好的ajax方法,利用原生封装AJax在使用的代码就要多得多,但是,原生封装AJax并不难,在刚接触到AJax时,相信很多人都不明白是什么东西,下面我举出两个例子、分别用原生封装Ajax实现demo与直接调用JQuery封装好的AJax来实现demo,帮助大家跟进一步的理解。

首先,大家在写原生AJax时,有下面四个步骤
1. 创建XMLHttpRequest对象,建立连接
var xmlhttp=new XMLHttpRequest();
2. 向服务器发送请求,设置配置参数
xmlhttp.open(“GET”,”test1.txt”,true);
xmlhttp.send();
3. 注册回调函数,服务器响应后执行一些基于响应的任务
xmlHttp.onreadystatechange = function () {};
4. 服务器响应


Demo1—原生封装

//1,封装Ajax函数
function Ajax(Obj) {
        //1,创建XMLHttpRequest对象,建立连接
        var xhr;
        if (window.XMLHttpRequest) {
            // code for IE7+, Firefox, Chrome, Opera, Safari
            xhr = new XMLHttpRequest();
        }
        else {// code for IE6, IE5
            xhr = new ActiveXObject("Microsoft.XMLHTTP");
        }
        //2,打开连接,配置参数
        xhr.open(Obj.type, Obj.url, Obj.async);
        xhr.send(null);
        //3,注册回调函数,服务器响应后执行一些基于响应的任务
        xhr.onreadystatechange = function () {
            // readyState == 4说明请求已完成
            if (xhr.readyState == 4 && xhr.status == 200) {
                // 4,服务器响应,从服务器获得数据,处理返回数据 
                var data = JSON.parse(xhr.responseText);
                Obj.success(data)

            }
        }
    }
//接下来,以上简单的封装完成,就可以使用了
    Ajax({
        type: 'get或者post方法',
        async: "是否异步",
        url: '接口地址',
        success: function (information) {
                 //响应成功后执行你想要的操作
        }
    });

Demo2–JQuery直接使用

   $.ajax({
             type: 'get或者post方法',
             async: "是否异步",
             url: '接口地址',
             success: function (information) {
                 //响应成功后执行你想要的操作
             }
        })

不难看出,使用时我们封装的Ajax函数就相当于JQuery封装好的函数$ .ajax

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值