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

JavaScript学习笔记(三十三)—jQuery(下)

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

jQuery

  • 今天我们继续来聊 jQuery

发送 ajax 请求

  • 发送 get 请求
// 直接使用 $.get 方法来发送一个请求
/*
 参数一: 请求地址
 参数二: 请求时携带的参数
 参数三: 请求成功的回调
 参数四: 返回的数据类型
*/
$.get('./ajax.php', { id: 10 }, function (res) { console.log(res) }, 'json')
  • 发送 post 请求
// 直接使用 $.post 方法来发送一个请求
/*
 参数一: 请求地址
 参数二: 请求时携带的参数
 参数三: 请求成功的回调
 参数四: 返回的数据类型
*/
$.post('./ajax.php', { id: 10 }, function (res) { console.log(res) }, 'json')
  • 综合发送 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,   // 选填,超时事件
})
  • 发送一个 jsonp 请求
// 使用 $.ajax 方法也可以发送 jsonp 请求
// 只不过 dataType 要写成 jsonp
$.ajax({
 url: './jsonp.php',
 dataType: 'jsonp',
 data: { name: 'Jack', age: 18 },
 success (res) {
 console.log(res)
    },
 jsonp: 'cb',  // jsonp 请求的时候回调函数的 key
 jsonpCallback: 'fn' // jsonp 请求的时候回调函数的名称
})

全局 ajax 函数

  • 全局的 ajax 函数我们也叫做 ajax 的钩子函数
  • 也就是在一个 ajax 的整个过程中的某一个阶段执行的函数
  • 而且每一个 ajax 请求都会触发

ajaxStart

  • 任意一个请求在 开始 的时候就会触发这个函数
$(window).ajaxStart(function () {
 console.log('有一个请求开始了')
})

ajaxSend

  • 任意一个请求在 准备 send 之前 会触发这个函数
$(window).ajaxSend(function () {
 console.log('有一个要发送出去了')
})

ajaxSuccess

  • 任意一个请求在 成功 的时候就会触发这个函数
$(window).ajaxSuccess(function () {
 console.log('有一个请求成功了')
})

ajaxError

  • 任意一个请求在 失败 的时候就会触发这个函数
$(window).ajaxError(function () {
 console.log('有一个请求失败了')
})

ajaxComplete

  • 任意一个请求在 完成 的时候就会触发这个函数
$(window).ajaxComplete(function () {
 console.log('有一个请求完成了')
})

ajaxStop

  • 任意一个请求在 结束 的时候就会触发这个函数
$(window).ajaxStop(function () {
 console.log('有一个请求结束了')
})

jQuery 的多库共存

  • 我们一直在使用 jQuery,都没有什么问题
  • 但是如果有一天,我们需要引入一个别的插件或者库的时候
  • 人家也向外暴露的是 $ 获取 jQuery
  • 那么,我们的 jQuery 就不能用了
  • 那么这个时候,jQuery 为我们提供了一个多库并存的方法
// 这个方法可以交还 jQuery 命名的控制权
jQuery.noConflict()

// 上面代码执行完毕以后 $ 这个变量就不能用了
// 但是 jQuery 可以使用
console.log($) // undefined
console.log(jQuery) // 可以使用
  • 完全交出控制权
// 这个方法可以交并且传递一个 true 的时候,会完全交出控制权
jQuery.noConflict(true)
?
// 上面代码执行完毕以后 $ 这个变量就不能用了
// jQuery 这个变量也不能用了
console.log($) // undefined
console.log(jQuery) // undefined
  • 更换控制权
// 可以用一个变量来接受返回值,这个变量就是新的控制权
var aa = jQuery.noConflict(true)
?
// 接下来就可以把 aa 当作 jQuery 向外暴露的接口使用了
aa('div').click(function () { console.log('我被点击了') })

JQuery 的插件扩展

  • jQuery 确实很好很强大
  • 但是也有一些方法是他没有的,我们的业务需求中有的时候会遇到一些它里面没有的方法
  • 那么我们就可以给他扩展一些方法


扩展给他自己本身

  • 扩展给自己本身使用 jQuery.extend 这个方法
  • 扩展完后的内容只能用 $ 或者 jQuery 来调用
// jQuery.extend 接受一个参数,是一个对象,对象里面是我们扩展的方法
jQuery.extend({
 max: function (...n) { return Math.max.apply(null, n) },
 min: function (...n) { return Math.min.apply(null, n) }
})
  • 扩展完毕我们就可以使用了
const max = $.max(4, 5, 3, 2, 6, 1)
console.log(max) // 6
const min = $.min(4, 5, 3, 2, 6, 1)
console.log(min) // 1

扩展给元素集

  • 扩展完毕以后给元素的集合使用
  • 也就是我们用 $('li') 这样的选择器获取到的元素集合来使用
  • 使用 jQuery.fn.extend() 方法来扩展
// jQuery.fn.extend() 接受一个参数,是一个对象,对象里面是我们扩展的方法
jQuery.fn.extend({
 checked: function () {
 // return 关键字是为了保证链式编程
 // 后面的代码才是业务逻辑
 return this.each(function() { this.checked = true })
    }
})
  • 扩展完毕我们就可以使用了
// 靠元素集合来调用
$('input[type=checkbox]').checked()
// 执行完毕之后,所有的 复选框 就都是选中状态了

相关推荐

基于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模块需要...

取消回复欢迎 发表评论: