AJAX的基本使用

AJAX的基本使用

🎉🎉🎉欢迎来到我的博客,我是一名自学了2年半前端的大一学生,熟悉的技术是JavaScript与Vue.目前正在往全栈方向前进, 如果我的博客给您带来了帮助欢迎您关注我,我将会持续不断的更新文章!!!🙏🙏🙏

文章目录

AJAX请求

创建XHR

创建XHR对象 XMLHttpRequest

XHR对象是一个javascript对象,它可以在用户没有感觉的情况下,就像背后运行的一根小线程一般,悄悄的和服务器进行数据交互

AJAX就是通过它做到无刷新效果的

javascript 复制代码
<script>
	var xmlhttp =new XMLHttpRequest();
	document.write(xmlhttp);
</script>

设置并发出请求

XHR对象的作用是和服务器进行交互,所以既会发消息给服务器,也能接受服务器返回的响应。

当服务器响应回来的时候,调用怎么处理呢?

通过xmlhttp.onreadystatechange=checkResult就可以指定用checkResult 函数进行处理。

设置并发出请求

通过open函数设置背后的这个小线程,将要访问的页面url ,在本例中就是

/study/checkName.jsp
xmlhttp.open("GET",url,true);

通过send函数进行实际的访问
xmlhttp.send(null);
null表示没有参数,因为参数已经通过GET 方式,放在url里了。

只有在用POST,并且需要发送参数的时候,才会使用到send

类似这样:
xmlhttp.send("user="+username+"&password="+password)

处理响应信息

在checkResult 函数中处理响应

javascript 复制代码
function checkResult(){
  if (xmlhttp.readyState==4 && xmlhttp.status==200)  
     document.getElementById('checkResult').innerHTML=xmlhttp.responseText;
}

xmlhttp.readyState 4 表示请求已完成
xmlhttp.status 200 表示响应成功
xmlhttp.responseText; 用于获取服务端传回来的文本
document.getElementById('checkResult').innerHTML 设置span的内容为服务端传递回来的文本

步骤

  1. 创建XHR对象
  2. 设置响应函数
  3. 设置要访问的页面
  4. 发出请求
  5. 当服务端的响应返回,响应函数被调用。
  6. 在响应函数中,判断响应是否成功,如果成功获取服务端返回的文本,并显示在span中。
javascript 复制代码
<span>输入账号 :</span>
<input id="name" name="name" onkeyup="check()" type="text"> 
<span id="checkResult"></span>
  
<script>
var xmlhttp;
function check(){
  var name = document.getElementById("name").value;
  var url = "https://how2j.cn/study/checkName.jsp?name="+name;
  
  xmlhttp =new XMLHttpRequest();
  xmlhttp.onreadystatechange=checkResult; //响应函数
  xmlhttp.open("GET",url,true);   //设置访问的页面
  xmlhttp.send(null);  //执行访问
}
  
function checkResult(){
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    document.getElementById('checkResult').innerHTML=xmlhttp.responseText;
   
}  
</script>

Hi👋,这里是瑞雨溪一个喜欢JavaScript和Vue的大学生,如果我的文章给你带来的帮助,欢迎您关注我,我会持续不断的更新更多优质文章.你的关注就是我的动力!!!🎉🎉🎉

相关推荐
孙凯亮5 小时前
前端DICOM Viewer开发避坑指南:从入门到实战(含切片、3D、标注全解析)
前端
代码搬运媛5 小时前
NestJS + TypeScript 全栈项目骨架实战
前端
Hilaku6 小时前
OpenClaw 跟病毒的区别是什么?
前端·javascript·人工智能
jerrywus6 小时前
AI 写代码总翻车?我用 Harness:developer 把它管成“右侧打工人”
前端·agent·claude
沸点小助手7 小时前
「国产龙虾谁能打过OpenClaw & 你敢让微信龙虾碰代码吗」沸点获奖名单公示|本周互动话题上新🎊
前端·后端·面试
skywalk81637 小时前
请学习kotti的前端(kotti其实是没有分离的前端的)实现,做到形似kotti那样的前端页面。
前端·学习
UI设计兰亭妙微7 小时前
兰亭妙微加载体验设计白皮书:从骨架屏到后台加载的全场景优化策略
前端·b端界面设计·ui设计公司
逆光如雪7 小时前
移动端卡片边框怎么做高级?我用 CSS 实现了设计师的刁钻要求
前端·css·vue.js
scan7247 小时前
龙虾读取session历史消息
java·前端·数据库
莹宝思密达7 小时前
地图显示西安经济开发区边界线-2023.12
前端·vue.js·数据可视化