zoukankan      html  css  js  c++  java
  • 封装原生JavaScript的ajax

    function obj2str(data) {
        data = data || {}; // 如果没有传参, 为了添加随机因子,必须自己创建一个对象
        data.t = new Date().getTime();
        var res = [];
        for (var key in data){
            //在URL中是不可以出现中文的,如果出现了中文需要转码,可以调用encodeURIComponent方法,URL中只可以出现字母、数字、下划线
            res.push(encodeURIComponent(key)+"="+encodeURIComponent(data[key]));
        }
        return res.join("&");
    }
    
    function myAjax(option){
        var params = obj2str(option.data);//key=value&key=value;
        var xmlhttp,timer;
        if (window.XMLHttpRequest){// code for IE7+, Firefox, Chrome, Opera, Safari
            xmlhttp=new XMLHttpRequest();
        }else{// code for IE6, IE5
            xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
        }
        
        if (option.type.toUpperCase()==="GET") {//toLowerCase将大写转化为小写
            xmlhttp.open("GET",option.url+"?"+params,true)
            xmlhttp.send();
        }else{
            xmlhttp.open("POST",option.url,true);
            xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
            xmlhttp.send(params);
        }
        xmlhttp.onreadystatechange = function (ev2) {
            if (xmlhttp.readyState === 4){
                clearInterval(timer);
                //判断是否请求成功(Http状态码大于等于200,且小于300,和状态码等于304为请求成功)
                if (xmlhttp.status>=200&&xmlhttp.status<300||xmlhttp.status===304) {
                    option.success(xmlhttp);
                }else{
                    option.error(xmlhttp);
                }
            }
        };
        if (option.timeout){
            timer = setInterval(function () {
                console.log("中断请求");
                xmlhttp.abort();
                clearInterval(timer);
            },option.timeout);
        }
    }
  • 相关阅读:
    day74 作业
    day73 基表 表关联
    不知道第几次分享了
    day72 序列化家族
    day72 作业
    vscode
    vuex
    linux python3.7的安装和配置
    使用多线程分批发送短信代码,分割list
    docker 容器里使用crontab不生效
  • 原文地址:https://www.cnblogs.com/ziwuxian/p/11777627.html
Copyright © 2011-2022 走看看