本文实例讲述了原生 js 封装的 ajax 方法. 分享给大家供大家参考, 具体如下:
众所周知, 框架之间会有冲突, 这是源生 js 就起到作用了, 下面介绍一种源生 js 封装的 ajax 请求.
- function ajax(options) {
- options = options || {};
- options.type = (options.type || "GET").toUpperCase();
- options.dataType = options.dataType || "json";
- var params = formatParams(options.data);
- // 创建 xhr 对象 - 非 IE6
- if (window.XMLHttpRequest) {
- var xhr = new XMLHttpRequest();
- } else { //IE6 及其以下版本浏览器
- var xhr = new ActiveXObject('Microsoft.XMLHTTP');
- }
- //GET POST 两种请求方式
- 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);
- }
- // 接收
- xhr.onreadystatechange = function () {
- if (xhr.readyState == 4) {
- var status = xhr.status;
- if (status>= 200 && status < 300) {
- options.success && options.success(xhr.responseText);
- } else {
- options.fail && options.fail(status);
- }
- }
- }
- }
- // 格式化参数
- 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({
- url: "data.json",
- type: "GET",
- data: {},
- dataType: "json",
- success: function (response) {
- // 此处放成功后执行的代码
- // 解析返回的字符串 转为 json 对象
- var usingdata = eval("("+response+")").data;
- }
- fail: function (status) {
- // 此处放失败后执行的代码
- }
- });
更多关于 JavaScript 相关内容感兴趣的读者可查看本站专题:JavaScript 中 ajax 操作技巧总结,JavaScript 错误与调试技巧总结,JavaScript 数据结构与算法技巧总结,JavaScript 遍历算法与技巧总结及JavaScript 数学运算用法总结
来源: http://www.jb51.net/article/144951.htm