关于Ajax寄己封装方法 和 使用jqurey方法对比

本文介绍如何使用原生JavaScript和jQuery实现AJAX无刷新表单提交,并比较两种方式的具体实现细节。

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

最近项目需要from表单无刷新提交,根据返回值改变页面参数 这种事交给ajax无疑是最佳的

直接撸代码吧!

首先是原生JavaScript封装ajax:

    function ajax(options) {
        options = options || {};
        options.type = (options.type || "GET").toUpperCase();   //--------字符串转换大写
        options.dataType = options.dataType || "json";
        var params = formatParams(options.data);

        //-----------创建对象 - 非IE6 - 第一步-----------
        if (window.XMLHttpRequest) {
            var xhr = new XMLHttpRequest();
        } else { //---------IE6及其以下版本浏览器-------------------
            var xhr = new ActiveXObject('Microsoft.XMLHTTP');
        }

        //-----------连接 和 发送 - 第二步
        if (options.type == "GET") {
            xhr.open("GET", options.url + "?" + params, true);
            xhr.send(null);      //--------------get请求默认为null
        } else if (options.type == "POST") {
            xhr.open("POST", options.url, true);
            //设置表单提交时的内容类型
            xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
            xhr.send(params);
        }

        //接收 - 第三步
        xhr.onreadystatechange = function () {
            if (xhr.readyState == 4) {
                if (xhr.status >= 200 && xhr.status < 300) {
                    options.success && options.success(xhr.responseText, xhr.responseXML);
                } else {
                    options.error && options.error(xhr.status);
                }
            }
        }
    }

    //格式化参数
    function formatParams(data) {
        var arr = [];
        for (var name in data) {
            arr.push(encodeURIComponent(name) + "=" + encodeURIComponent(data[name]));
        }
        arr.push(("v=" + Math.random()).replace(".", ""));
        console.log(arr);
        return arr.join("&");
    }

    var form = document.getElementById('myForm');
    var save = document.getElementById('save');
    save.onclick = function () {
    //实例调用
        ajax({
            url: "http://localhost:8080/zcbishe/getBook",
            type: "post",
            data: {name: '001'},
            dataType: "json",
            success: function (response, xml) {
                // 成功后执行的代码
                console.log(JSON.parse(response))
            },
            error: function (status) {
                // 失败后执行的代码
            }
        });
        return false;
    }

对比下jqurey的方法:

  var $=jQuery;
       $("#save").click(function(){
           url = 'http://localhost:8080/zcbishe/getBook';
           htmlobj = $.ajax({
               type : "POST",
               url : url,
               data : $('#myForm').serialize(), //把表单序列化
               async : false,
               success:function(data,textStatus,jqXHR){
                   console.log(data)
                   console.log(textStatus)
                   console.log(jqXHR)
               }
           });

           return false;//阻止页面刷新
       });

个人喜欢原生,使用类库太累赘哈哈,

但是jqurey在阻止了表单的默认submit事假后,可以直接序列化参数

$('#myForm').serialize()
原生代码我还没有找到方法  后面找到方法在补充

如有大神路过 请指教  万分感谢~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值