/*
注意:
1、检查提交方式类型:get/post是否和后台一致(该类型接口文档会标注,若一致仍然报错,请与后台再次确认)
2、检查接口url是否写错
3、检查接口是否需要传数据到后台,若需上传,便仔细把自己上传的数据和接口文档上对比,
观察有没有错写、多写、少写,数据格式是否正确(一般和后台人员确认一下要传什么数据格式),观察上传的值是否会出现undefined
4、若以上都正确了还是报错,那么便让后台人员看看是否是后台程序出错(一般http状态码返回500就是后台程序出错,但是也不排除是前端传递过去的数据不对导致后台报错)
6、如果出现跨域问题,就找后台解决

*/

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>ajax封装</title>
</head>
<body>
<!-- ajax:异步的javascript和XML,能够向服务器请求额外的数据而无需卸载页面,会带来更好的用户体验,包含XML但与ajax通信与数据格式无关 -->
<!-- ajax核心:XMLHttpRequert对象(简称XHR);request(请求) -->
<script type="text/javascript">
// 封装
function ajax(method,_url,data,fun) {
// 1、定义一个xhr变量存放ajax对象
var xhr;
// 2、当window对象里面存在XMLHttpRequest时
if (window.XMLHttpRequest) {
// 实例化一个XMLHttpRequest()构造函数
xhr = new XMLHttpRequest();
} else {
// 为防止一些浏览器中没有XMLHttpRequest
// 当window对象里面没有XMLHttpRequest时就实例化一个ActiveXObject()构造函数
xhr = new ActiveXObject("Microsoft.XMLHTTP");
} // 3、使用XHR时要调用open(a1,a2,a3);方法a1:请求类型,a2:请求的url,a3:是否发送异步请求(ture/false)
xhr.open(method,_url,true); // 4、send();请求在主体发送的数据
// 发送请求如果需要发送到服务器的端的数据,那么send(data) ,data:数据 需转换为字符串类型的
xhr.send(JSON.stringify(data));
//当readyState值每发生一次变化就调用一次onreadystatechange方法
xhr.onreadystatechange = function() {
// readystate为4代表已经接收全部响应数据,并且已经可以在客户端使用
if (xhr.readyState == 4) {
// readystate:状态为200时表示请求已经完全成功
if (xhr.status == 200) {
// responseText:作为响应主体被返回的文本
// JSON.parse():将字符串json转换为数组类型的json
// 把返回的数据responseText从string转换为JSON数据格式并打印出来
fun(JSON.parse(xhr.responseText));
}
}
}
} // 调用封装好的函数
ajax("get","http://192.168.95.237:81/ajaxapi/public/index.php/api/api/index",null,function(data){
document.body.innerHTML=data.code;
}); // post提交
var data={
stuid:"1027"
}
ajax("post","http://192.168.95.237:81/ajaxapi/public/index.php/api/api/selectuserid",data,function(data){
document.body.innerHTML=data.code;
}); /*
注意:
1、检查提交方式类型:get/post是否和后台一致(该类型接口文档会标注,若一致仍然报错,请与后台再次确认)
2、检查接口url是否写错
3、检查接口是否需要传数据到后台,若需上传,便仔细把自己上传的数据和接口文档上对比,
观察有没有错写、多写、少写,数据格式是否正确(一般和后台人员确认一下要传什么数据格式),观察上传的值是否会出现undefined
4、若以上都正确了还是报错,那么便让后台人员看看是否是后台程序出错(一般http状态码返回500就是后台程序出错,但是也不排除是前端传递过去的数据不对导致后台报错)
6、如果出现跨域问题,就找后台解决 */
</script>
</body>
</html>

封装好的Ajax的更多相关文章

  1. 不借助jquery封装好的ajax,你能用js手写ajax框架吗

    不借助jquery封装好的ajax,你能手写ajax框架吗?最基础的ajax框架,一起来围观吧. .创建XMLHttpRequest对象 var xhr = new XMLHttpRequest(); ...

  2. 封装通用的 ajax, 基于 jQuery。

    在前端异步获取数据时候每次都是使用 ajax:为了通用性更好,然而封装通用的 ajax 是一个一劳永逸的办法. 本次基于 jQuery 封装实现: 第一步: 引入 jQuery: <script ...

  3. 封装、调用ajax

    1.JavaScript代码 //封装ajaxfunction ajax(obj) { var xhr = new createXHR(); obj.url = obj.url + '?rand=' ...

  4. 封装JavaScript的AJAX

    // 创建request对象 function createXMLHttpRequest() { try { return new XMLHttpRequest();//大多数浏览器 } catch ...

  5. 封装自己的Ajax框架

    Ajax技术就是利用javascript和xml实现异步交互的功能. 首先先来介绍一下Ajax相关知识点 一.Ajax对象的创建 1.创建Ajax对象的方式 a.第一种方式是针对IE浏览器 b.第二种 ...

  6. AJAX的来龙去脉(由来)-如何被封装出来的--ajax发送异步请求(四步操作)

    <黑马程序员_超全面的JavaWeb视频教程vedio\JavaWeb视频教程_day23_ajax> \JavaWeb视频教程_day23_ajax\day23ajax_avi\14.打 ...

  7. 使用es6的then()方法封装jquery的ajax请求

    使用场景: jsp页面中使用jquery的ajax请求比较频繁,以前vue框架的项目用过axios,所以就想着用then()封装一个公共请求的方法,这样每次请求就不用那么麻烦的写一大堆请求参数了. 示 ...

  8. 封装JS实现Ajax

    这两天仔细理解了一下Ajax,然后整理封装了一下,如果有什么不对的地方,请指教,谢谢! AJAX AJAX = Asynchronous JavaScript and XML(异步的 JavaScri ...

  9. 超简单 Promise封装小程序ajax 超好用 以及封装登录

    //网络类 //封装网络请求 const ajax = (ajaxData, method) => { wx.showLoading({ title: '加载中', mask: true }); ...

  10. 封装springmvc处理ajax请求结果

    原文链接:http://blog.csdn.net/qq_37936542/article/details/79064818 需求描述:ajax向后台发起请求,springmvc在处理完请求后返回的结 ...

随机推荐

  1. C++ STL——类型转换

    目录 一 类型转换 注:原创不易,转载请务必注明原作者和出处,感谢支持! 注:内容来自某培训课程,不一定完全正确! 一 类型转换 类型转换的含义是通过改变一个变量的类型为别的类型从而改变变量的表示方式 ...

  2. 在CentOS7阿里云服务器部署ThinkPHP5,并配置phpstrom实现同步开发(微信小程序及管理员后端)

    小程序和后端同步开发 1.服务器安装tp5框架: 方法很多比如:github.linux命令直接手动下.composer 都可以,方法很多,百度一下,不再累述 2.这时你会发现怎么都访问出现不了这个令 ...

  3. 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_6-1.常用的第三方支付和聚合支付介绍

    笔记 第六章 开发在线教育视频站点核心业务之从零基础接入 微信扫一扫网页支付 1.常用的第三方支付和聚合支付介绍     简介:介绍常用的第三方支付和聚合支付 1.什么是第三方支付         第 ...

  4. 小D课堂-SpringBoot 2.x微信支付在线教育网站项目实战_5-1.数据信息安全--微信授权一键登录功能介绍

    笔记 1.数据信息安全--微信授权一键登录功能介绍 简介:讲解登录方式优缺点和微信授权一键登录功能介绍         1.手机号或者邮箱注册             优点:              ...

  5. java序列化与反序列化操作redis

     笔者在使用SSM框架项目部分功能进行测试需要使用到对象的序列化与反序列化 第一种方式:jackson Demo package com.dznfit.service; import com.dznf ...

  6. 在jsp页面如何获得url参数

    方法一:当一个url过来时,如:http://localhost:8080/pro/demo/hello.jsp?name=john,在hello.jsp页面,我们可以这样得到name的值: < ...

  7. Elasticsearch聚合问题

    在测试Elasticsearch聚合的时候报了一个错误.具体如下: GET /megacorp/employee/_search { "aggs": { "all_int ...

  8. Python-sympy科学计算与数据处理(方程,微分,微分方程,积分)

    方程 a,b,c,x = symbols("a b c x") my_eq = Eq(a*x**2+b*x+c,0) solve(my_eq,x) Out[12]: [(-b + ...

  9. 如何使用delphi将Clientdataset的Delta保存到数据库中

    [delphi] view plain copy //ATableName-表名, AKeyField-主键,多个主键用;隔开,如 ;pid;times; from:unit HlsImplBase; ...

  10. Linux shell脚本重试机制

    重试机制在实际编程场景中应用比较场景,比如你的任务在请求一个正在写入数据但不确定什么时间会完成的文件,可能就需要通过尝试机制间隔一段时间重新执行任务. 以下 shell 脚本是实现重试机制的模板: # ...