zoukankan      html  css  js  c++  java
  • ajax

    ajax({
    url: "./TestXHR.aspx", //请求地址
    type: "POST", //请求方式
    data: { name: "super", age: 20 }, //请求参数
    dataType: "json",
    success: function (response, xml) {
    // 此处放成功后执行的代码
    },
    fail: function (status) {
    // 此处放失败后执行的代码
    }
    });

    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');
    }

    //接收 - 第三步
    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, true);
    xhr.send(null);
    } else if (options.type == "POST") {
    xhr.open("POST", options.url, true);
    //设置表单提交时的内容类型
    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("&");
    }

  • 相关阅读:
    [转] jQuery 操作 JSON 数据
    [转] 8张图学习javascript
    HTML文档类型声明的坑...
    Android 应用内HttpClient 与 WebView 共享 Cookie
    李嘉诚无锡演讲
    keytool 生成 Android SSL 使用的 BKS
    LeetCode-344-反转字符串
    LeetCode-342-4的幂
    LeetCode-338-比特位计数
    LeetCode-326-3的幂
  • 原文地址:https://www.cnblogs.com/dingyuanxin/p/4074281.html
Copyright © 2011-2022 走看看