原生js封装ajax方法
来源:互联网 发布:python 99乘法表思路 编辑:程序博客网 时间:2024/05/18 01:21
有时候我们不想使用 jquery等框架,想实现简单的ajax,如果需要用js原生代码又比较多,比较复杂,在这里我们对ajax进行封装,让其使用简单
/* 封装ajax函数 * @param {string}opt.type http连接的方式,包括POST和GET两种方式 * @param {string}opt.url 发送请求的url * @param {boolean}opt.async 是否为异步请求,true为异步的,false为同步的 * @param {object}opt.data 发送的参数,格式为对象类型 * @param {function}opt.success ajax发送并接收成功调用的回调函数 */ function ajax(opt) { opt = opt || {}; opt.method = opt.method.toUpperCase() || 'POST'; opt.url = opt.url || ''; opt.async = opt.async || true; opt.data = opt.data || null; opt.success = opt.success || function () {}; var xmlHttp = null; if (XMLHttpRequest) { xmlHttp = new XMLHttpRequest(); } else { xmlHttp = new ActiveXObject('Microsoft.XMLHTTP'); }var params = []; for (var key in opt.data){ params.push(key + '=' + opt.data[key]); } var postData = params.join('&'); if (opt.method.toUpperCase() === 'POST') { xmlHttp.open(opt.method, opt.url, opt.async); xmlHttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded;charset=utf-8'); xmlHttp.send(postData); } else if (opt.method.toUpperCase() === 'GET') { xmlHttp.open(opt.method, opt.url + '?' + postData, opt.async); xmlHttp.send(null); } xmlHttp.onreadystatechange = function () { if (xmlHttp.readyState == 4 && xmlHttp.status == 200) { opt.success(xmlHttp.responseText);//如果是json数据可以在这使用opt.success(JSON.parse( xmlHttp.responseText)) } }; }
使用范例
ajax({ method: 'POST', url: 'test.php', data: { name1: 'value1', name2: 'value2' }, success: function (response) { console.log(response); }});
原文:http://www.cnblogs.com/a757956132/p/5603176.html
阅读全文
0 0
- 原生js封装ajax方法
- 原生JS封装ajax方法
- 原生js封装ajax方法
- 原生js封装Ajax
- 原生js封装ajax
- 原生JS封装Ajax
- 原生JS封装ajax()
- JS 原生方法封装
- 原生JS封装AJAX请求
- 原生js封装ajax函数
- js 原生ajax:封装函数
- 原生js封装ajax函数
- 原生js封装ajax请求
- 一个原生js操作Ajax封装
- 怎么用原生js封装ajax函数
- 怎样用原生js封装ajax函数
- 如何用原生JS封装Ajax
- 原生JS如何运动ajax封装函数
- iOS GCD的冰山一角
- php程序常用自检错误方法
- RecyclerView的简单使用
- 离散题目7
- Property 'X' not found on type entity.Customer错误原因分析
- 原生js封装ajax方法
- ### laravel--day2 路由
- 直方图匹配
- CentOS7下Java虚拟机监控
- MVC中Action过滤器(OnActionExecuting,OnActionExecuted,OnResultExecuting,OnResultExecued)
- [Leetcode] 213. House Robber II 解题报告
- RTMP协议分析——神文,非常详细
- mysql常用函数(字符串函数,数值函数,日期和时间函数)
- 如何搭建开源code review gerrit服务器