百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

详解如何实现前端jquery中的ajax方法,看这一篇就够了

qiyuwang 2024-10-21 09:39 11 浏览 0 评论

前言

这篇文章主要聊一聊如何手写一个jquery的ajax方法,这是前端中的基础知识,也是一道非常经典的前端面试题!

一步步手写ajax

在web页面中与后端通信的顺序一般都是客户端向服务器发起请求,然后服务器再回复客户端,用于通信的工具就是ajax。如果你喜欢足球,你肯定知道荷甲联赛中也有一支豪门足球俱乐部叫阿贾克斯,名字一毛一样。ajax就像电话一样,将页面和服务器联系在一起,基本用法如下:

从图1中我们可以看出$.ajax是一个函数,它的参数是一个对象,那么我们可以像如下这样定义:

var $ = {}; // 模拟jquery对象
$.ajax = function(options){
	// 实现逻辑
}

接下来我们就开始写函数里面的逻辑。

如图2,ajax的关键在于XMLHttpRequest对象,它提供了对http协议的安全访问接口,这里使用了它的两个方法和一个事件:

1)open方法的第一个参数是请求类型:get、post、head等,第二个参数是请求的接口地址,第三个参数表示ajax请求是异步(true)还是同步(false),如果是异步,在ajax发送完请求后js会继续执行,不会等待服务器响应,我们一般选择异步,提高页面的渲染效率;

2)send方法只有一个参数,表示向服务器发送的参数,一般是对象;

3)onreadystatechange是一个事件,它可以监听从请求开始到结束整个过程的状态,状态保存在xhr的readyState属性中。

readyState状态:

  • 0代表未初始化,open方法还未执行;
  • 1代表正在加载,open已被执行但send还未被执行;
  • 2代表已经加载完毕,send已被执行,请求已被发送;
  • 3代表正在等待服务器响应;
  • 4代表响应已经完成。

从上面readyState状态我们可以看出,ajax只需要4的情况,其他状态其实都是失败!

另外,xhr的status属性代表服务器返回的状态码,根据我们的经验,状态码在400以上都是有问题的,要么是服务端问题,要么就是客户端问题!300到400之间好像都和重定向有关系,但是有一个除外——304,如果你了解浏览器缓存,你肯定知道它和协商缓存有关系,其实它代表请求成功!另外200以下的状态都需要请求者继续操作,也不符合要求!总结一下,可用的状态码就是200到300之间,加一个304!

好了,经过上面的分析,我们继续完善onreadystatechange事件的处理函数:

如图3,在事件处理函数中我们写了两个方法ajaxSuccess和ajaxError,它们分别执行ajax参数对象传入的success和error这两个函数属性。我们知道ajax对象参数中还一个属性叫complete,这是一个方法,无论请求成功与否,它都会被执行,所以它在ajaxSuccess和ajaxError中都需要被调用执行一次。xhr.responseText代表服务器返回的数据,xhr.statusText代表状态码对应的状态信息。

接下来我们还需要设置请求头,可以用xhr.setRequestHeader来完成,如下:

图4中,我们对两个比较特殊的请求头做了默认设置(Accept和Content-type),其中当我们用post类型向服务器发送请求并且带有参数,此时content-type需要设置为application/x-www-form-urlencoded,其他的请求头可以通过ajax的对象参数headers属性传入。注意setRequestHeader方法需要在open方法之后调用!

在有些场景下,我们需要在发送请求前做一些逻辑判断,如果不满足条件我们需要阻止请求的发送,为了满足需求,我们需要在ajax调用open方法之前添加一个钩子!

图5中我们通过beforeSend函数的执行结果判断是否需要取消请求!

写到这里其实还有一步没做,那就超时逻辑,比如在网络不好的情况下,我们不能让页面一直处于loading状态,需要设置一个超时时间,超过这个时间就代表ajax请求失败!开发超时的需求,我们最容易想到的是利用定时器setTimeout,现在我们补上!

如图6,在超时的情况下,我们将onreadystatechange事件处理函数置为一个空函数并且放弃这次请求,然后执行error函数,另外在正常的onreadystatechange事件处理逻辑中我们需要及时清除这个定时器!

写到这里,一个简单的ajax就已经开发完了,现在直接把demo拿去使用也是没有问题的!

常见面试题

1、手写一个ajax?

如果你看到这里我想应该没什么问题了!

2、如果请求发生了重定向,ajax会怎么处理?

当然是进入了error函数中!

3、如果请求发生了超时,ajax会怎么处理?

当然也是进入了error函数中!

总结

本篇文章手写的ajax可以直接用于移动端,未考虑PC端兼容性!根据我的经验,只要能手写出ajax,面试中遇到相关问题就不会被难住,此类问题其实就是送分题!另外多说一点,开发PC页面时我们使用的是jquery,而开发移动端时我们应该使用zepto.js!本篇文章就写到这里,下一篇接着写JSONP的实现!

喜欢我的文章就关注我吧,有问题可以发表评论,我们一起学习,共同成长!

相关推荐

基于Docker方式安装与部署Camunda流程引擎

1Camunda简介官网:https://docs.camunda.org/manual/7.19/installation/docker/Camunda是一个轻量级、开源且高度灵活的工作流和决策自...

宝塔Linux面板如何部署Java项目?(宝塔面板 linux)

通过宝塔面板部署Java还是很方便的,至少不需要自己输入tomcat之类的安装命令了。在部署java项目前,我还是先说下目前的系统环境,如果和我的系统环境不一样,导致部署不成功,那你可能需要去找其他资...

浪潮服务器如何用IPMI安装Linux系统

【注意事项】此处以浪潮服务器为例进行演示所需使用的软件:Chrome浏览器个人PC中需要预先安装java,推荐使用jdk-8u181-windows-x64.exe【操作步骤】1、在服务器的BIOS中...

Centos7环境Hadoop3集群搭建(hadoop集群环境搭建实验报告)

由于项目需要存储历史业务数据,经过评估数据量会达到100亿以上,在原有mongodb集群和ES集群基础上,需要搭建Hbase集群进行调研,所以首先总结一下Hadoop集群的搭建过程。一、三个节点的集群...

Hadoop高可用集群搭建及API调用(hadoop高可用原理)

NameNodeHA背景在Hadoop1中NameNode存在一个单点故障问题,如果NameNode所在的机器发生故障,整个集群就将不可用(Hadoop1中虽然有个SecorndaryNameNo...

使用Wordpress搭建一个属于自己的网站

现在开源的博客很多,但是考虑到wordpress对网站的seo做的很好,插件也多。并且全世界流量排名前1000万的网站有33.4%是用Wordpress搭建的!所以尝试用Wordpress搭建一个网站...

Centos 安装 Jenkins(centos 安装ssh)

1、Java安装查看系统是否已安装Javayumlistinstalled|grepjava...

Java教程:gitlab-使用入门(java中的git)

1导读本教程主要讲解了GitLab在项目的环境搭建和基本的使用,可以帮助大家在企业中能够自主搭建GitLab服务,并且可以GitLab中的组、权限、项目自主操作...

Dockerfile部署Java项目(docker部署java应用)

1、概述本文主要会简单介绍什么是Docker,什么是Dockerfile,如何安装Docker,Dockerfile如何编写,如何通过Dockerfile安装jar包并外置yaml文件以及如何通过do...

如何在Eclipse中搭建Zabbix源码的调试和开发环境

Zabbix是一款非常优秀的企业级软件,被设计用于对数万台服务器、虚拟机和网络设备的数百万个监控项进行实时监控。Zabbix是开放源码和免费的,这就意味着当出现bug时,我们可以很方便地通过调试源码来...

Java路径-02-Java环境配置(java环境搭建及配置教程)

1Window环境配置1.1下载...

35.Centos中安装python和web.py框架

文章目录前言1.Centos7python:2.Centos8python:3.进行下载web.py框架然后应用:4.安装好之后进行验证:5.总结:前言...

《我的世界》服务器搭建(我的世界服务器如何搭建)

1.CentOS7环境1.1更改YUM源#下载YUM源文件curl-o/etc/yum.repos.d/CentOS-Base.repohttps://mirrors.aliyun.com...

CentOS 7 升级 GCC 版本(centos7.4升级7.5)

1.GCC工具介绍GCC编译器:...

Linux安装Nginx详细教程(linux安装配置nginx)

环境准备1.因为Nginx依赖于gcc的编译环境,所以,需要安装编译环境来使Nginx能够编译起来。命令:yuminstallgcc-c++显示完毕,表示安装完成:2.Nginx的http模块需要...

取消回复欢迎 发表评论: