jQuery中ajax的相关知识点汇总

 更新时间:2021年03月08日 11:48:18   作者:三七安  
这篇文章主要给大家介绍了关于jQuery中ajax相关知识点的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

学习JavaScript的同学都知道, AJAX (async javascript and
xml)翻译叫做异步的JavaScript和XML , 在原生js中使用发送网络请求也是一件麻烦事,每次都是那几个步骤.

我们先来回顾一下在原生js中如何发送一个 ajax 网络请求

经典4步曲

1.原生js的ajax网络请求

 // IE9及以上
 // const xhr = new XMLHttpRequest()
 // IE9以下
 // const xhr = new ActiveXObject('Mricosoft.XMLHTTP')

 // 对于这个兼容写法我们可以用一个函数来封装
 function createXHR() {
 var req = null;
 if (window.XMLHttpRequest) {
 // 如果有这个XMLHttpRequest对象就直接使用
 req = new XMLHttpRequest();
 } else {
 // 否则就使用IE8一下的写法
 req = new ActiveXObject("Microsoft.XMLHTTP");
 }
 return req;
 }
 // 第一步:创建ajax对象
 var xhr = createXHR(); //这样就拿到了一个ajax对象
 // 第二步:配置网络请求信息

 xhr.open('get', './demo.php', true)
 // xhr.open('get/post','要发送网络请求去哪个地址',同步还是异步默认 true 表示异步,false 表示同步)
 // 如果是get请求有参数需要拼接在地址后面,例如'./demo.php?id=2&name=sanqi'
 // 如果是post请求,参数就要放在send()里面,例如:xhr.send('id=2&name=sanqi')
 // 第三步:发送网络请求
 xhr.send() //
 // 第四部:判断响应状态拿到数据
 xhr.onreadyStateChange = function () {
 // 每次 readyState 改变的时候都会触发该事件
 // 我们就在这里判断 readyState 的值是不是到 4
 // 并且 http 的状态码是不是 200 ~ 299
 if (xhr.readyState === 4 && /^2\d{2|$/.test(xhr.status)) {
 // 这里表示验证通过
 // 我们就可以获取服务端给我们响应的内容了
 console.log(xhr.response);
 }
 }


这里补充一下readyState的5个状态

  • readyState --> 0: 表示未初始化完成,也就是 open 方法还没有执行
  • readyState --> 1: 表示配置信息已经完成,也就是执行完 open 之后
  • readyState --> 2: 表示 send 方法已经执行完成
  • readyState --> 3: 表示正在解析响应内容
  • readyState --> 4: 表示响应内容已经解析完毕,可以在客户端使用了

上面就是原生的js发送一个ajax网络请求

2.关于使用jQuery的ajax网络请求

我们在学习jquery,就了解到,大家都在说,什么 jq 都给我们封装好啦,这些网络请求都不用我们去写啦,虽说如此,但是也还是不能盲目,还是 要具体了解之后才会使用.

(1).利用jquery发送get请求

下面统一后端代码使用文件名为: test.php 这个文件

<?php
header('content-type:text/html;charset=utf-8;');
 $id = $_REQUEST['id'];
 $name = $_REQUEST['name'];
 $arr = [
 'id' => $id,
 'name' => $name
 ];
 echo json_encode($arr);
?>

使用jquery发送get请求

  $.get('./test.php','id=999&name=三七安',function (res) { 
  //第一个参数是请求的地址
  //第二个参数是要发送给服务器的数据
  //第三个参数是成功时的回调函数,里面包含服务返回给我们的数据
  //第四个参数是我们希望拿到的数据格式:有几种选择:json,text,html,xml,script
  console.log(res);
  },'json')

可以看到请求是发送成功了的

(2) 利用jquery发送post请求

	 $.post('./test.php',{id:123,name:'post请求'},function (res) { 
	 //这里其他参数和get请求一致的
	 //注意,这里的传输数据我用 对象的格式来写,也能发送请求成功,也就是说
	 //无论是get请求还是post请求,想服务端传数据,既可以使用字符串格式也可以使用对象格式
  console.log(res);
  },'json')

这是请求成功的的页面

(3)利用jquery发送综合发送 ajax 请求

先来浏览一下语法

 // 使用 $.ajax 方法
 // 只接受一个参数,是一个对象,这个对象对当前的请求进行所有的配置
 $.ajax({
  url: './ajax', // 必填,请求的地址
  type: 'GET', // 选填,请求方式,默认是 GET(忽略大小写)
  data: {}, // 选填,发送请求是携带的参数
  dataType: 'json', // 选填,期望返回值的数据类型,默认是 string
  async: true, // 选填,是否异步,默认是 true
  success() {}, // 选填,成功的回调函数
  error() {}, // 选填,失败的回调函数
  cache: true, // 选填,是否缓存,默认是 true
  context: div, // 选填,回调函数中的 this 指向,默认是 ajax 对象
  status: {}, // 选填,根据对应的状态码进行函数执行
  timeout: 1000, // 选填,超时事件
 })

好像每次都要填好多参数,但其实大部分参数都是选填的,我们只要看实际情况来填写

在编译器里面,直接输入ajax也可以快捷生成部分代码

发送ajax请求代码

$.ajax({
  type: "get",
  url: "./test.php",
  data: {
   id:000,
   name:'发送$.ajax请求的演示'
  },
  dataType: "json",
  success: function (response) {
   console.log(response);
  }
  });

打开网页就可以看到我们从后端拿回来的数据

下面补充几个Ajax的全局函数,也叫钩子函数,也就是在Ajax整个请求过程中的某一个阶段执行的函数,而且是任意一个Ajax请求都会触发.

1. ajaxStart, 任意一个请求开始的时候都会触发这个函数

$(window).ajaxStart(function () {
 console.log('有一个请求开始了')
})

2. ajaxSend , 任意一个 请求准备send之前都会触发这个请求.

$(window).ajaxSend(function () {
 console.log('有一个要发送出去了')
})

3.ajaxSuccess, 任意一个 请求成功的时候都会触发这个函数.

$(window).ajaxSuccess(function () {
 console.log('有一个请求成功了')
})

4.ajaxError , 任意一个 请求失败的时候就会触发这个函数.

$(window).ajaxError(function () {
 console.log('有一个请求失败了')
})

5.ajaxComplete , 任意一个 请求完成的时候就会触发这个函数

$(window).ajaxComplete(function () {
 console.log('有一个请求完成了')
})

6.ajaxStop , 任意一个 请求结束的时候就会触发这个函数

$(window).ajaxStop(function () {
 console.log('有一个请求结束了')
})

总结

到此这篇关于jQuery中ajax的相关知识点汇总的文章就介绍到这了,更多相关jQuery ajax知识点内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于jquery css3实现点击动画弹出表单源码特效

    基于jquery css3实现点击动画弹出表单源码特效

    这篇文章主要介绍了基于jquery css3实现点击动画弹出表单,弹出的表单没有任何遮盖层,在web前端程序开发中经常会用到,需要的朋友可以参考下
    2015-08-08
  • jQuery实现仿京东防抖动菜单效果示例

    jQuery实现仿京东防抖动菜单效果示例

    这篇文章主要介绍了jQuery实现仿京东防抖动菜单效果,结合实例形式分析了jQuery事件响应及页面属性动态操作相关实现技巧,需要的朋友可以参考下
    2018-07-07
  • jackson解析json字符串,首字母大写会自动转为小写的方法

    jackson解析json字符串,首字母大写会自动转为小写的方法

    下面小编就为大家分享一篇jackson解析json字符串,首字母大写会自动转为小写的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12
  • ztree实现权限横向显示功能

    ztree实现权限横向显示功能

    最近在做权限功能的时候,采用的ztree实现的,但是产品要求最后一层的权限节点要横向显示。下面小编把基于ztree实现权限横向显示功能的实现思路分享给大家,供大家参考
    2017-05-05
  • jquery 获取 outerHtml 包含当前节点本身的代码

    jquery 获取 outerHtml 包含当前节点本身的代码

    jQuery.html() 是获取当前节点下的html代码,并不包含当前节点本身的代码,后来实验发现有一个jQuery的一个方法可以解决
    2014-10-10
  • 基于JQuery的6个Tab选项卡插件

    基于JQuery的6个Tab选项卡插件

    今天在修整博客侧栏信息时,利用到了Tab选项卡方式,因为ZBlog封装的是JQuery库,所以很自然地就想到了IdTabs。
    2010-09-09
  • jQuery EasyUI 组件加上“清除”功能实例详解

    jQuery EasyUI 组件加上“清除”功能实例详解

    在使用 EasyUI 各表单组件时,尤其是使用 ComboBox(下拉列表框)、DateBox(日期输入框)、DateTimeBox(日期时间输入框)这三个组件时,经常会遇到下拉框或日期只允许选择、不允许手动输入功能,怎么解决呢,下面小编给大家分享解决方案,一起看看吧
    2017-04-04
  • jQuery侧边栏随窗口滚动实现方法

    jQuery侧边栏随窗口滚动实现方法

    jQuery侧边栏随窗口滚动实现方法,需要的朋友可以参考一下
    2013-03-03
  • jquery click([data],fn)使用方法实例介绍

    jquery click([data],fn)使用方法实例介绍

    大概意思就是触发每一个匹配元素的click事件,本文通过一个实例为大家详细介绍下jquery click([data],fn)的使用方法,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-07-07
  • jQuery实现简单漂亮的Nav导航菜单效果

    jQuery实现简单漂亮的Nav导航菜单效果

    这篇文章主要介绍了jQuery实现简单漂亮的Nav导航菜单效果,涉及jQuery响应鼠标事件动态遍历与操作页面元素属性的相关实现技巧,需要的朋友可以参考下
    2017-03-03

最新评论