用JS写的一个Ajax库
来源:互联网 发布:小号手模型淘宝旗舰店 编辑:程序博客网 时间:2024/06/06 07:30
myajax是一个用js编写的一个跨浏览器的ajax库,支持get, post, jsonp请求,精巧,简单。
一、发送GET请求:
myajax.get({<span style="white-space:pre"></span>data: {}, //参数url: "", //请求地址//发生错误是调用error: function(data) {},//请求成功调用success: function(data){<span style="white-space:pre"></span>//eval(data); 将字符串转换成json}});二、发送POST请求:
myajax.post({data: {}, //参数url: "", ////发生错误是调用error: function(data) {},//请求成功调用success: function(data){//eval(data); 将字符串转换成json}});
三、发送JSONP请求:
myajax.getJSONP({//参数data: {},url: "", //请求地址//请求成功调用success: function(data) {},//发生错误时调用error: function() {}});
var myajax = {post: function(params){var xmlhttp = this.createXMLHttpRequest();if (xmlhttp != null){var async = true;if (typeof params.async != "undefined")async = params.async;var data = null;if (typeof params.data != "undefined")data = params.data;var url = "";if (typeof params.url != "undefined")url = params.url;if (url == null || url.length == 0)return;xmlhttp.open("POST", url, async);if (async){xmlhttp.onreadystatechange = function(){if (this.readyState==4){if (this.status==200){if (typeof params.success != "undefined") {params.success(xmlhttp.responseText);}}else {if (typeof params.error != "undefined") {params.error(xmlhttp.status + xmlhttp.statusText);}console.error(url + ": " + xmlhttp.status);}}};}xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");var param = "";for (var prop in data) {param += prop + "=" + data[prop] + "&";}param = param.substring(0, param.length - 1);xmlhttp.send(param);if (!async) {if (xmlhttp.readyState == 4 && xmlhttp.status == 200)if (typeof params.success != "undefined") {params.success(xmlhttp.responseText);}else {if (typeof params.error != "undefined") {params.error(xmlhttp.status + xmlhttp.statusText);}console.error(url + ": " + xmlhttp.status);}}}},get: function(params){var xmlhttp = this.createXMLHttpRequest();if (xmlhttp != null){var async = true;if (params.async != undefined)async = params.async;var url = "";if (params.url != undefined)url = params.url;if (url == null || url.length == 0)return;if (params.data != null) {var data = params.data;var paramPrefix = url.indexOf("?") == -1 ? "?" : "&";url = url + paramPrefix;for (var prop in data) {url += prop + "=" + data[prop] + "&";}url = url.substring(0, url.length - 1);}xmlhttp.open("GET", url, async);if (async){xmlhttp.onreadystatechange = function(){if (this.readyState==4){if (this.status==200){if (typeof params.success != "undefined") {params.success(xmlhttp.responseText);}}else {if (typeof params.error != "undefined") {params.error(xmlhttp.status + xmlhttp.statusText);}console.error(url + ": " + xmlhttp.status);}}};}xmlhttp.send(null);if (!async) {if (xmlhttp.readyState == 4 && xmlhttp.status == 200)if (typeof params.success != "undefined") {params.success(xmlhttp.responseText);}else {if (typeof params.error != "undefined") {params.error(xmlhttp.status + xmlhttp.statusText);}console.error(url + ": " + xmlhttp.status);}}}},createXMLHttpRequest: function(){if (window.XMLHttpRequest){return new XMLHttpRequest();}else if (window.ActiveXObject){//code for IE5 and IE6return new ActiveXObject("Microsoft.XMLHTTP");}return null;},getJSONP: function(params) {var url = null;if (typeof params.url != "undefined") {url = params.url;}if (url == null) {return;}var ff = "" + new Date().getTime() + (parseInt(Math.random() * 10000000000));eval("jsonpCallback_" + ff + "=" + function(data){if (typeof params.success != "undefined") {params.success(data);}});//根据url中是否出现过 "?" 来决定添加时间戳参数时使用 "?" 还是 "&" var paramPrefix = url.indexOf("?") == -1 ? "?" : "&";url = url + paramPrefix + "jsonpCallback=" + "jsonpCallback_" + ff;var param = "";if (typeof params.data != "undefined" && params.data != null) {var data = params.data;for (var prop in data) {param += prop + "=" + data[prop] + "&";}param = param.substring(0, param.length - 1);}if (param.length > 0)url = url + "&" + param; var script = document.createElement("script"); document.body.appendChild(script); script.src = url; script.charset ="UTF-8";// for firefox, google etc.script.onerror = function() {if (typeof params.error != "undefined") {params.error();} }script.onload = function() {document.body.removeChild(script); } // for ie script.onreadystatechange = function() { if (this.readyState == "loaded" || this.readyState == "complete") { document.body.removeChild(script); } }}};
0 0
- 用JS写的一个Ajax库
- 先写一个用ajax开发webgis的JS暂停函数问题!
- JS写的AJAX调用
- 纯js写的Ajax
- 一个用JS写的树状目录
- 用js写的一个跑马灯
- 用JS写的一个日历
- 用JS写的一个简易计算器
- 用js写的一个手风琴效果
- 用js写一个简单的进度条
- 用js写的一个红绿灯程序
- 用js写一个简单的聊天室
- 用js写一个简单的计算器
- 用JS写Ajax的请求函数(1)
- 自己写的一个用AJAX实现的留言系统
- 一个纯js的ajax
- 分享一个用DHTML写的一个js简易轮播图
- 原生JS写Ajax的请求函数
- FutureTask
- [寒江孤叶丶的CrossApp之旅_04][入门系列]修改CrossApp默认打开的Window(窗口)
- 建造者模式
- 最短路算法总结
- maven 创建工程,下载依赖
- 用JS写的一个Ajax库
- [CAFFE]DIY Deep Learning for Vision: A Tutorial With Caffe 报告笔记
- 遇到问题----win7下80端口被(Pid=4)占用的解决方法
- The Python Tutorial 8——Errors and Exceptions
- 高通APQ8074 spi 接口配置
- JavaScript编码函数escape()、encodeURI()、encodeURIComponent()区别
- Lua协同程序coroutine
- centos源码安装PHP
- "parse error before *"