美文网首页
Ajax的使用

Ajax的使用

作者: 星球小霸王 | 来源:发表于2017-09-14 20:29 被阅读0次

    Js原生ajax的使用

    1.首先创建一个XMLHttpRequest()对象

          var xhr = XMLHttpRequest()
    

    2.然后配置open()方法

    open()有三个属性配置
    比如

    xhr.open("get","http://local host/add.php",true)
    

    第一个参数代表"get"或者"post",请求
    第二个地址为要请求的地址
    第三个参数true代表是异步请求

    3.发送

    xhr.send()
    //发送请求
    

    如果是get请求send()不加参数,参数拼接到url 后面
    如果是post请求,将传递的参数当到send()方法内发送
    比如,发送一个id=10的数据
    xhr.send("id=10")

    4.监听状态

    通过xhr.onreadystatechange来监听服务器状态
    当xhr.readyState = 4 && xhr.status = 200的时候,说明服务器响应成功

          xhr.onreadystatechange = function(){
                 if( xhr.readyState = 4 && xhr.status = 200){
                //这时候说明数据请求成功,成功的数据会存放在xhr.responseText属性中
              var data = xhr.responseText.
              console.log(data)//这里就是从后台请求的数据,然后通过js将对应的数据渲染到页面上
             /*在这里通常都是拼接字符串的操作,
              所以当我们拼接字符串的时候可以将整个字符串放到一个数组里
              然后通过数组的join()方法将数组拼接成字符串可以简化字符串拼接的错误)*/
              }
           }
    

    如果需要跨域,就需要设置头部信息

    xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded")
    

    原生js封装的ajax请求,需要的自行带走(解决ie兼容性问题)

    function ajax(options) {
            options = options || {};
            options.type = (options.type || "GET").toUpperCase();
            options.dataType = options.dataType || "json";
            options.async = options.async==false?false:true;
            var params = formatParams(options.data);
    
            //创建 - 非IE6 - 第一步
            if (window.XMLHttpRequest) {
                var xhr = new XMLHttpRequest();
            } else { //IE6及其以下版本浏览器
                var xhr = new ActiveXObject('Microsoft.XMLHTTP');
            }
    
            //接收 - 第三步
            xhr.onreadystatechange = function () {
                if (xhr.readyState == 4) {
                    var status = xhr.status;
                    if (status >= 200 && status < 300) {
                        options.success && options.success(xhr.responseText, xhr.responseXML);
                    } else {
                        options.fail && options.fail(status);
                    }
                }
            }
    
            //连接 和 发送 - 第二步
            if (options.type == "GET") {
                xhr.open("GET", options.url + "?" + params, options.async);
                xhr.send(null);
            } else if (options.type == "POST") {
                xhr.open("POST", options.url, options.async);
                //设置表单提交时的内容类型
                xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
                xhr.send(params);
            }
        }
        //格式化参数
        function formatParams(data) {
            var arr = [];
            for (var name in data) {
                arr.push(encodeURIComponent(name) + "=" + encodeURIComponent(data[name]));
            }
            arr.push(("v=" + Math.random()).replace(".",""));
            return arr.join("&");
        }
    

    相关文章

      网友评论

          本文标题:Ajax的使用

          本文链接:https://www.haomeiwen.com/subject/dgnrsxtx.html