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

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

qiyuwang 2024-10-21 09:40 7 浏览 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()
// 执行完毕之后,所有的 复选框 就都是选中状态了

相关推荐

windows开启telnet服务,检测远程服务端口是否可以连通

本文介绍windwos开启telnet服务,telnet服务一般可以用于检测远程主机的某个端口服务是否可以连通,在日常的工作中,我们经常会遇到在本地的windows检测远程服务端口是否可以连通。win...

仅在Web登录新华三交换机条件下启用设备Telnet登录方式

概述Web登录新华三交换机可以在“网络-服务”页面中启用设备Telnet服务或SSH服务,也可以在“设备-管理员”设置管理员用户的可用服务,然而,在设备Web页面中,无法设置lineVTY用户线【l...

思科交换机,路由器如何关闭telnet 开启ssh服务

SSH为建立在应用层基础上的安全协议。SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用SSH协议可以有效防止远程管理过程中的信息泄露问题。今天我们就来说说思科交换机,路...

智能化弱电行业常用的DOS命令,掌握了你也能成为...

前言在做智能化弱电项目时,前端摄像头设备安装结束后,我们会对网络摄像头进行调试,调试过程中会遇到前端摄像头没有图像或者图像出来了画面卡顿的现象。我们会采用ping命令来测试网络的连通性和网络承载能力。...

「干货」eNSP模拟器之配置Telnet登录

配置说明:配置Telnet,使R2(模拟PC)通过SW1登录到R1进行管理和配置。操作步骤:system-view##进入系统视图[Huawei]sysnameR1##改名为R1[R1]int...

win11开启telnet服务怎么操作 win11打开telent指令是什么

telnet服务是我们在进行远程连接的时候,必须要打开的一项功能。但是有不少用户们不清楚在windows11系统中怎么开启telnet服务。今天小编就使用详细的图文教程,来给大家说明一下打开telen...

华三(H3C)交换机Telnet的远程登陆

一,配置交换机管理IP[SW1]vlan20//创建管理vlan[SW1]interfacevlan20//进入vlan接口[SW1-Vlanif20]ipaddress192.168....

win10 telnet命令怎么查看端口是否打开

可能大家也会遇到这个问题,win10telnet命令查看端口是否打开的步骤是什么?具体方法如下:1、键盘输入快捷键WIN+R,打开运行窗口。2、输入cmd,点击确定按钮。3、弹出cmd命令行窗...

Windows 7如何打开Telnet功能(win7系统打开telnet)

Windows7默认安装后是没有开启telnet客户端功能的,例如,我们在开始菜单中输入cmd,然后使用telnet命令,会弹出下图提示:‘telnet’不是内部或外部命令,也不是可运行程序或批处理文...

为锐捷路由器交换机开启web和telnet,实现轻松管理

笔者上一篇文章写了关于锐捷二层交换机配置教程,那么接下来讲一下锐捷的路由交换设备配置web、telnet技巧。同样,今天的教程也是基于命令行,比较简单,适合新手小白进行学习。准备工作配置前准备:con...

一文学会telnet命令的用途和使用方法

Telnet是一个古老的远程登录协议,可以让本地计算机获得远程计算机的工作能力。它采用了TCP的可靠连接方式,可以连接任何网络互通的远程计算机。不过由于它采用了明文传输方式,存在安全风险,目前已经很少...

Telnet命令是什么?如何使用?(telnet命令在哪里开启)

telnet命令是一个常用的远程登陆工具,使用它,我们可以快捷地登陆远程服务器进行操作。那么如何使用telnet命令呢?首先,我们需要打开telnet功能,任何电脑默认是关闭此功能的,开启方式如下:打...

win11系统如何开启telnet服务(拷贝版本)

  我们要知道,Telnet协议是Internet远程登陆服务的标准协议,可以使用户在本地计算机上完成远程主机的工作,不过对于一些刚接触win11中文版系统的用户来说,可能还不知道telnet服务在哪...

如何开启telnet客户端(如何开启telnet服务)

Telnet协议是TCP/IP协议家族中的一员,是Internet远程登陆服务的标准协议和主要方式,Telnet是常用的远程控制Web服务器的方法。工作中经常用到telnet客户端,但在windows...

Telnet 是什么,如何启用它?(telnet有什么用)

对于Internet等TCP/IP网络,Telnet是一个终端仿真程序。Telnet软件在您的系统上运行并将您的个人计算机链接到网络服务器。它将所有数据转换为纯文本这一事实被认为是易受...

取消回复欢迎 发表评论: