jQuery的事件-动画-AJAX和插件

一、jQuery事件处理

1.认识事件(Event)

Web页面经常需要和用户之间进行交互,而交互的过程中我们可能想要捕捉这个交互的过程:

  • 比如用户点击了某个按钮、用户在输入框里面输入了某个文本、用户鼠标经过了某个位置;
  • 浏览器需要搭建一条JavaScript代码和事件之间的桥梁;
  • 当某个事件发生时,让JavaScript执行某个函数,所以我们需要针对事件编写处理程序(handler);

原生事件监听方法:

  • 事件监听方式一:在script中直接监听(很少使用)。
  • 事件监听方式二:DOM属性,通过元素的on来监听事件。
  • 事件监听方式三:通过EventTarget中的addEventListener来监听。

jQuery事件监听方法:

  • 事件监听方式一:直接调用jQuery对象中的事件处理函数来监听,例如:click,mouseenter…。
  • 事件监听方式二:调用jQuery对象中的on函数来监听,使用off函数来取消监听。
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><ul id="list" class="panel"><li class="li-1">li-1</li><li class="li-2">li-2</li><li class="li-3">li-3</li><li class="li-4">li-4</li><li class="li-5">li-5</li></ul><button class="cancel">取消事件的监听</button><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {// 监听事件// 1.使用on来监听事件$('ul').on('click', function() {console.log('click1')})// 2.使用click来监听事件$('ul').click(function() {console.log('click2')})// 3.使用mouseenter来监听事件$('ul').mouseenter(function() {console.log('mouseenter')})// 取消监听事件$('.cancel').click(function() {// $('ul').off() // 取消ul元素上所有的事件// $('ul').off('mouseenter')$('ul').off('click')})// 使用程序-自动触发事件// $('ul').trigger('click')  // 模拟用户点击了ul元素$('ul').trigger('mouseenter')})</script>
</body>
</html>

2.click和on的区别

click和on的区别:

  • click是on的简写。它们重复监听,不会出现覆盖情况,都支持事件委托,底层用的是addEventListener。
  • 如果 on 没有使用 selector 的话,那么和使用click是一样的。
  • on 函数可以接受一个 selector 参数,用于筛选 可触发事件 的后代元素。
  • on 函数支持给事件添加命名空间。
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><ul id="list" class="panel"><li class="li-1">li-1</li><li class="li-2">li-2</li><li class="li-3">li-3</li><li class="li-4">li-4</li><li class="li-5">li-5</li></ul><button class="cancel">取消事件的监听</button><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {// 监听事件// 1.使用on来监听事件 ( 支持给事件添加命名空间: liujun )$('ul').on('click.liujun', function() {console.log('click1')})// 2.使用click来监听事件$('ul').click(function() {console.log('click2')})// 取消监听事件$('.cancel').click(function() {$('ul').off('click.liujun')})/*1.on 监听的事件支持使用 命名空间2.on 函数支持一个 selector 的参数*///  $('ul').on('click', '字符串类型的选择器', function() {//  })})</script>
</body>
</html>

3.click和on中this指向

click和on的this指向:

  • this都是指向原生的DOM Element
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><ul id="list" class="panel"><li class="li-1">li-1</li><li class="li-2">li-2</li><li class="li-3">li-3</li><li class="li-4">li-4</li><li class="li-5">li-5</li></ul><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {// $('ul').click(function() {//   console.log("%O", this) // DOM Element -> UL// }) // $('ul').on('click', function() {//   console.log(this) // DOM Element -> UL// })// $('ul li').click(function() {//   console.log(this) // DOM Element -> UL// })// 底层实现的原理// var lisEl = $('ul li').get() // [li, li, li]// for(var liEL of lisEl ){//   liEL.addEventListener('click', function() {//     console.log(this)//   })// }// $('ul li').click(function() {//   console.log( $(this) ) // DOM Element 转成 jQuery 对象// })$('ul li').click(() => {console.log(this)})})</script>
</body>
</html>

4.jQuery的事件冒泡

我们会发现默认情况下事件是从最内层(如下图span)向外依次传递的顺序,这个顺序我们称之为事件冒泡(Event Bubble);

事实上,还有另外一种监听事件流的方式就是从外层到内层(如:body -> span),这种称之为事件捕获(Event Capture);

为什么会产生两种不同的处理流呢?

  • 这是因为早期在浏览器开发时,不管是IE还是Netscape公司都发现了这个问题;

  • 但是他们采用了完全相反的事件流来对事件进行了传递;

  • IE<9仅采用了事件冒泡的方式,Netscape采用了事件捕获的方式;

  • IE9+和现在所有主流浏览器都已支持这两种方式。

jQuery为了更好的兼容IE浏览器,底层并没有实现事件捕获。

5.jQuery的事件对象( Event Object)

jQuery事件系统的规范是根据W3C的标准来制定jQuery事件对象。原始事件对象的大多数属性都被复制到新的jQuery事件 对象上。如,以下原生的事件属性被复制到jQuery事件对象中: altKey, clientX, clientY, currentTarget, data, detail, key, keyCode, offsetX, offsetY, originalTarget, pageX, pageY, relatedTarget, screenX, screenY, target, …

jQuery事件对象通用的属性(以下属性已实现跨浏览器的兼容):

  • target、relatedTarget、pageX、pageY、which、metaKey

jQuery事件对象常用的方法:

  • preventDefault() : 取消事件的默认行为(例如,a标签、表单事件等)。
  • stopPropagation() : 阻止事件的进一步传递(例如,事件冒泡)。

要访问其它事件的属性,可以使用 event.originalEvent 获取原生对象。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.box{width: 200px;height: 200px;background-color: pink;}.content{display: inline-block;width: 50px;height: 50px;background-color: green;}</style>
</head>
<body><div class="box">div<span class="content">span</span></div><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {// 1.获取原生的事件对象// var divEl = document.querySelector('.box')// divEl.addEventListener('click', function(event) {//   console.log(event)// })// 2.获取jQuery的事件对象$('.box').click(function($event) {console.log($event) // 是jQuery的事件对象console.log($event.originalEvent) // 拿到原生的事件对象})})</script>
</body>
</html>

6.jQuery的事件委托(event delegation)

事件冒泡在某种情况下可以帮助我们实现强大的事件处理模式 – 事件委托模式(也是一种设计模式)

那么这个模式是怎么样的呢?

  • 因为当子元素被点击时,父元素可以通过冒泡监听到子元素的点击;

  • 并且可以通过event.target获取到当前监听事件的元素(event.currentTarget获取到的是处理事件的元素);

案例:一个ul中存放多个li,使用事件委托的模式来监听li中子元素的点击事件。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>ul li.item {width: 200px;height: 80px;margin-bottom: 10px;background-color: #ccc;}</style>
</head>
<body><script src="./utils/jquery-3.7.1.min.js"></script><script>$(function () {$('ul').on('click', 'li.item', function(event) {console.log($(event.target).text()+"被点击了")})})</script><ul><li class="item">item1</li><li class="item">item2</li><li class="item">item3</li><li class="item">item4</li><li class="item">item5</li></ul>
</body>
</html>

7.jQuery常见的事件

鼠标事件(Mouse Events)

  • .click() 、.dblclick()、.hover()、.mousedown() 、.mouseup()
  • .mouseenter()、.mouseleave()、.mousemove()
  • .mouseover()、.mouseout() 、.contextmenu()、.toggle()

键盘事件(Keyboard Events)

  • .keydown() 、.keypress()、.keyup()

文档事件(Document Loading Events)

  • load、ready()、.unload

表单事件(Form Events)

  • .blur() 、.focus()、.change()、.submit()、.select()

浏览器事件(Browser Events)

  • .resize()、.scroll()
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><ul id="list" class="panel"><li class="li-1">li-1</li><li class="li-2">li-2</li><li class="li-3">li-3</li><li class="li-4">li-4</li><li class="li-5">li-5</li></ul><input type="text"><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {// on('hover', func)// 1.hover 底层使用的是: mouseenter or mouseleaver// $('ul').hover(function() {//   console.log('鼠标悬浮在ul')// }, function() {//   console.log('鼠标离开在ul')// })// 2.监听浏览器resize事件 ( throttle 节流 )// on('resize', func)$(window).resize(function() {console.log('resize')})// 3.表单事件$('input').focus(function() {console.log('input focus事件')})$('input').blur(function() {console.log('input blur事件')})// input ( debounce 防抖操作 )$('input').on('input', function() {//  console.log( $('input').val() )console.log( $(this).val() )})})</script>
</body>
</html>

8.mouseover和mouseenter的区别

mouseenter()和mouseleave()

  • 不支持冒泡
  • 进入子元素依然属于在该元素内,没有任何反应

mouseover()和mouseout()

  • 支持冒泡
  • 进入元素的子元素时
    • 先调用父元素的mouseout
    • 再调用子元素的mouseover
    • 因为支持冒泡,所以会将mouseover传递到父元素中;

9.jQuery的键盘事件

事件的执行顺序是 keydown()、keypress()、keyup()

  • keydown事件先发生;
  • keypress发生在文本被输入;
  • keyup发生在文本输入完成(抬起、松开);

我们可以通过key和code来区分按下的键:

  • code:“按键代码”(“KeyA”,“ArrowLeft” 等),特定于键盘上按键的物理位置。
  • key:字符(“A”,“a” 等),对于非字符(non-character)的按键,通常具有与 code 相同的值。)

10.jQuery的表单事件

表单事件(Form Events)

  • .blur() - 元素失去焦点时触发
  • .focus() - 元素获取焦点时触发
  • change() - 该事件在表单元素的内容改变时触发( , , , 和 )
  • .submit() - 表单提交时触发( <input> <keygen> <select> <textarea>)

二、jQuery 动画

1.jQuery动画操作-animate

.animate(): 执行一组 CSS属性的自定义动画,允许支持数字的CSS属性上创建动画。

  • .animate( properties [, duration ] [, easing ] [, complete ] )
  • .animate( properties, options )
    • propertys参数的支持:
      • 数值:number 、string
      • 关键字:‘show’、‘hide’和’toggle’
      • 相对值:+= 、 -=
      • 支持 em 、% 单位(可能会进行单位转换)。

自定义修改宽高度动画

  • height :100% -> 0
  • width: 100% -> 0
  • opacity: 1 - > 0
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.box{width: 200px;height: 100px;background-color: pink;}</style>
</head>
<body><button class="hide">隐藏</button><button class="show">显示</button><div class="box">box</div><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {$('.hide').click(function() {// 需要一个隐藏的动画$('.box').animate({height: 0, // 100px -> 0pxwidth: 0, // 200px -> 0pxopacity: 0 // 1 -> 0},2000, 'swing' , function() {console.log('动画执行完毕之后会回调')})})$('.show').click(function() {$('.box').animate({height: 100,width: 200,opacity: 1}, function() {console.log('动画执行完毕之后会回调')})// $('.box').animate({//   height: 100,//   width: 200,//   opacity: 1// }, 2000, 'swing', function() {//   console.log('动画执行完毕之后会回调')// })// $('.box').animate({//   height: 100,//   width: 200,//   opacity: 1// }, {//   duration: 'slow',//   complete: function() {//     console.log('动画执行完毕之后会回调')//   }// })})})</script>
</body>
</html>

2.jQuery常见动画函数

显示和隐藏匹配的元素

  • .hide() 、.hide( [duration ] [, complete ] )、.hide( options ) - 隐藏元素
  • .show() 、.show( [duration ] [, complete ] )、.show( options ) - 显示元素
  • .toggle() 、.toggle( [duration ] [, complete ] )、.toggle( options ) -显示或者隐藏元素

淡入淡出

  • .fadeIn()、.fadeIn( [duration ] [, complete ] )、.fadeIn( options ) - 淡入动画

  • .fadeOut()、.fadeOut( [duration ] [, complete ] )、.fadeOut( options ) -淡出动画

  • .fadeToggle()、.fadeToggle( [duration ] [, complete ] )、.fadeToggle( options ) - 淡入淡出的切换

  • .fadeTo( duration, opacity [, complete ] ) - 渐变到

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>body{height: 200px;}.box{width: 200px;height: 100px;background-color: pink;}</style>
</head>
<body><button class="hide">隐藏</button><button class="show">显示</button><button class="toggle">切换</button><div class="box">box</div><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {$('.hide').click(function() {$('.box').hide('slow', function() {console.log('动画执行完成')})})$('.show').click(function() {$('.box').show('fast', function() {console.log('动画执行完成')})})$('.toggle').click(function() {// $('.box').toggle(2000)$('.box').toggle({duration: 3000,complete: function() {console.log('动画执行完成')}})})})</script>
</body>
</html>

3.jQuery元素中的动画队列

jQuery匹配元素中的animate和delay动画是通过一个动画队列(queue)来维护的。例如执行下面的动画都会添加到动画队列中:

  • .hide() 、 .show()
  • .fadeIn() 、.fadeOut()
  • .animate()、delay()

.queue():查看当前选中元素中的动画队列。

.stop( [clearQueue ] [, jumpToEnd ] ):停止匹配元素上当前正在运行的动画。

  • clearQueue :一个布尔值,指示是否也删除排队中的动画。默认为false
  • jumpToEnd :一个布尔值,指示是否立即完成当前动画。默认为false
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.box{position: relative;width: 100px;height: 100px;background-color: pink;}</style>
</head>
<body><button class="start">开始动画</button>  <button class="stop">停止动画</button>  <button class="queue">查看动画队列</button> <div class="box">box</div><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {var $box = $('.box')$('.start').click(function() {$box.animate({top: 100}, 5000)$box.animate({left: 100}, 5000)$box.animate({top: 0}, 5000)$box.animate({left: 0}, 5000)})$('.queue').click(function() {console.log( $box.queue() )  // 查看动画队列 fx})$('.stop').click(function() {// $box.stop()  // 停止 fx 动画队列( 停止当前执行的动画,还会继续执行动画队列中其它的动画 )// stop(false, false) 默认值// $box.stop(true) // 停止所有的动画, 清空了动画队列//  $box.stop(true, true) // 清空了动画队列, 立即执行完当前的动画})})</script>
</body>
</html>

4.jQuery实现-隐藏侧边栏广告

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.box{position: fixed;bottom: 0;right: 0;}img{vertical-align: bottom;}.close{position: absolute;top: 0;right: 0;width: 25px;height: 25px;cursor: pointer;/* border: 1px solid red; */}</style>
</head>
<body><div class="box"><span class="close"></span><div class="top"><img src="./images/top.png" alt=""></div><div class="bottom"><img src="./images/bottom.png" alt=""></div></div><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {$('.close').click(function() {$('.bottom').animate({height: 0}, 600, function() {$('.box').animate({width: 0}, 600, function() {$('.box').css('display', 'none')})})})})</script>
</body>
</html>

5.jQuery中的遍历

.each( function ): 遍历一个 jQuery 对象,为每个匹配的元素执行一个回调函数。

  • function 参数:
    • Function( Integer index, Element element ), 函数中返回false会终止循环。

jQuery.each( array | object , callback ) : 一个通用的迭代器函数,可以用来无缝地迭代对象和数组。

  • array参数:支持数组(array)或者类数组(array-like),底层使用for循环 。

  • object参数: 支持普通的对象 object 和 JSON对象等,底层用for in循环。

  • function 参数:

    • Function( Integer index, Element element ), 函数中返回false会终止循环。

.each() 和 jQuery.each()函数的区别:

  • .each()是jQuery对象上的方法,用于遍历 jQuery对象。
  • jQuery.each( ) 是jQuery函数上的方法,可以遍历对象、数组、类数组等,它是一个通用的工具函数。
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><ul id="list" class="panel"><li class="li-1">li-1</li><li class="li-2">li-2</li><li class="li-3">li-3</li><li class="li-4">li-4</li><li class="li-5">li-5</li></ul><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {// 1.遍历jQuery对象 ( 已经实现了迭代器协议 for of )// 对象中的 each 底层调用的 jQuery函数上的each方法$('ul li').each(function(index, element) {  // [].forEach( func(element, index, array ))console.log(index, element)})console.log("%O", $('ul') )// 2.使用 for of})</script>
</body>
</html>

三、jQuery AJAX

1.jQuery的AJAX

在前端页面开发中,如果页面中的数据是需要动态获取或者更新的,这时我们需要向服务器发送异步的请求来获取数据,然后在无需刷新页面的情况来更新页面。那么这个发起异步请求获取数据来更新页面的技术叫做AJAX

AJAX全称(Asynchronous JavaScript And XML),是异步的 JavaScript 和 XML,它描述了一组用于构建网站和Web应用程序的开发技术。

  • 简单点说,就是使用 XMLHttpRequest 对象与服务器通信。它可以使用 JSON,XML,HTML 和 text 文本等格式发送和接收数据。
  • AJAX 最吸引人的就是它的“异步”特性。也就是说它可以在不重新刷新页面的情况下与服务器通信,交换数据,或更新页面。

AJAX请求方法(Method)

  • GET、POST、PUT、PACTH、DELETE 等

jQuery中也有AJAX模块,该模块是在XMLHttpRequest的基础上进行了封装,语法(Syntax)如下:

  • $.ajax( [settings ] ) - 默认用 GET 请求从服务器加载数据, 会返回jQXHR对象,可以利用该对象的abort方法来取消请求。

  • $.get( url [, data ] [, success ] [, dataType ] ) - 发起GET请求,底层调用的还是$ajax()

  • $.post( url [, data ] [, success ] [, dataType ] ) - 发起POST请求,底层调用的还是$ajax()

初体验jQuery中的AJAX

  • https://httpbin.org (是一个专门提供:免费测试http服务的网站

2.AJAX请求参数(Parameters)

请求参数(Parameters)

  • url - 指定发送请求的 URL。
  • method / type - 用于指定请求的类型 (e.g. “POST”, “GET”, “PUT”),默认为GET
  • data - 指定要发送到服务器的数据(PlainObject or String or Array)
  • processData:当data是一个对象时,jQuery 从对象的键/值对生成数据字符串,除非该processData选项设置为false. 例如,{ a: “bc”, d: “e,f” }被转换为字符串"a=bc&d=e%2Cf",默认为true。
  • header - 请求头的内容(PlainObject)
  • contentType - 默认值:application/x-www-form-urlencoded; charset=UTF-8,向服务器发送数据时指定内容类型。
    • application/x-www-form-urlencoded; charset=UTF-8: 请求体的数据以查询字符串形式提交,如:a=bc&d=e%2Cf。
    • application/json; charset=UTF-8 指定为json字符串类型
    • 为时 false, 代表是 multipart/form-data 。表单类型,一般用于上传文件
  • dataType - 期望服务器端发回的数据类型(json、xml、text…),默认会根据响应的类型来自动推断类型。
  • timeout - 请求超时时间。它以毫秒为单位。
  • beforeSend - 这是一个在发送请求之前运行的函数,返回false会取消网路请求。
  • success - 请求成功回调的函数
  • error - 请求失败回调的函数
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><ul id="list" class="panel"><li class="li-1">li-1</li><li class="li-2">li-2</li><li class="li-3">li-3</li><li class="li-4">li-4</li><li class="li-5">li-5</li></ul><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {// console.log(encodeURIComponent('天河公园'))// 1.url 添加查询字符串// $.ajax({//   url: 'http://httpbin.org/get?cityId=404100&keyWord=天河公园',//   method: "GET",//   success: function(res) {//     console.log(res)//   }// })// 2.支持在data中提交参数// $.ajax({//   url: 'http://httpbin.org/get',//   method: "GET",//   data: {//     cityId: '504100',//     keyWord: '小蛮腰'//   },//   success: function(res) {//     console.log(res)//   }// })// 3.给 get请求添加请求头// $.ajax({//   url: 'http://httpbin.org/get',//   method: "GET",//   data: {//     cityId: '504100',//     keyWord: '小蛮腰'//   },//   headers: {  // 比如你登录成功之后,后台会返回一个 token//      accessToken: 'aaaaabbbbbcccccc' //   },//   success: function(res) {//     console.log(res)//   }// })// 4.get简写 $.get('http://httpbin.org/get').then(function(res) {  // jQuery 1.8  ; doneconsole.log(res)}).catch(function() {  //  failconsole.log('catch')}).always(function() {  // finally  console.log('always')})})</script>
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><ul id="list" class="panel"><li class="li-1">li-1</li><li class="li-2">li-2</li><li class="li-3">li-3</li><li class="li-4">li-4</li><li class="li-5">li-5</li></ul><script src="../libs/jquery-3.6.0.js"></script><script>// 1.监听文档完全解析完成$(function() {// 1. 在url中提交查询字符串(比较少见)// $.ajax({//   url: 'http://httpbin.org/post?cityId=404100&keyWord=天河公园',//   method: "POST",//   success: function(res) {//     console.log(res)//   }// })// 2. 在data中提交查询字符串// $.ajax({//   url: 'http://httpbin.org/post',//   method: "POST",//   data: {//     cityId: '504100',//     keyWord: '小蛮腰'//   },//   // contentType: 'application/x-www-form-urlencoded; charset=UTF-8',//   // dataType: 'json', // 自动推断, response content-type//   success: function(res) {//     console.log(res)//   }// })// 3. 在data中 JSON 字符串// $.ajax({//   url: 'http://httpbin.org/post',//   method: "POST",//   data: JSON.stringify({//     cityId: '504100',//     keyWord: '小蛮腰'//   }),//   contentType: 'application/json; charset=UTF-8',//   success: function(res) {//     console.log(res)//   }// })// 4. 在data中 FormData// var formData = new FormData()  // <form> <input name="cityId" value="404100"/> <input name="keyWord" value="小蛮腰"/>   </form>// formData.append('cityId', 404100)// formData.append('keyWord', '小蛮腰')// // formData.append('file', 文件)// $.ajax({//   url: 'http://httpbin.org/post',//   method: "POST",//   data: formData,//   processData: false, // processData:true, 会将data为对象的转成查询字符串//   contentType: false, // 使用 原生 XHR 默认的 contentType//   success: function(res) {//     console.log(res)//   }// })// 5. 在添加请求头// var formData = new FormData()// formData.append('cityId', 404100)// formData.append('keyWord', '小蛮腰')// $.ajax({//   url: 'http://httpbin.org/post',//   method: "POST",//   data: formData,//   processData: false, // processData:true, 会将data为对象的转成查询字符串//   contentType: false, // 使用 原生 XHR 默认的 contentType//   headers: {//     liujunToken: 'xxxxxxxsssssssssssd'//   },//   success: function(res) {//     console.log(res)//   }// })// 6. POST简写$.post('http://httpbin.org/post', {cityId: '504100',keyWord: '小蛮腰'}).then(function(res) {console.log(res)})})</script>
</body>
</html>

四、jQuery插件开发

在我们开发时,有时候jQuery提供的方法并不能满足我们的需求。如果我们想给jQuery扩展一些其它的方法,那这种情况下, 可能需要编写一个插件。

  • jQuery插件其实就是:编写一些新增的方法,并将这些方法添加到jQuery的原型对象上。

编写jQuery 插件的步骤:

  • 新建一个插件对应的JS文件(命名规范:jquery.插件名.js)
  • 在立即执行函数中编写插件,这样可以避免插件中的变量与全局变量冲突。
  • 在jQuery的原型对象上新增一些的方法。
  • 最后在html中导入就可以像使用其他 jQuery对象方法一样使用了
  • 到此就开发完一个jQuery的插件了。

案例:开发一个 jquery.showlinklocation.js 的插件。

  • 功能:让网页上所有的a标签文本的后面追加对应的域名地址。
;(function(window, $) {// 1.在jquery的原型上添加了一个 showlinklocation// $.fn.showlinklocation = function() {//   console.log(this) // jQuery对象//   this.append('(http://www.liujun.com)')// }// 2.需要过滤出a元素// $.fn.showlinklocation = function() {//   console.log(this) // jQuery对象//   this.filter('a').append('(http://www.liujun.com)')// }// 3.需要遍历a元素$.fn.showlinklocation = function() {console.log(this) // jQuery对象this.filter('a').each(function() {var $a = $(this) // DOM Elementvar link = $a.attr('href')$a.append(`(${link})`)})return this}// 
})(window, jQuery)
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><ul id="list" class="panel"><li class="li-1">li-1</li><li class="li-2">li-2</li><li class="li-3">li-3</li><li class="li-4">li-4</li><li class="li-5">li-5</li></ul><a href="https://www.jd.com">京东商城</a><a href="https://www.taobao.com">淘宝商城</a><a href="https://www.biyao.com">必要商城</a><script src="../libs/jquery-3.6.0.js"></script><script src="./utils/jquery.showlinklocation.js"></script><script>// 1.监听文档完全解析完成$(function() {$('a').showlinklocation().css('color', 'red')})</script>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/579170.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用vite创建vue3项目

1、使用管理员身份打开命令行窗口&#xff0c;输入命令: npm create vuelatest TypeScript语法选择是&#xff0c;其他依次选择否&#xff0c;创建完毕。 2、 创建完毕后打开项目&#xff0c;vscode会提示安装开发相关的插件&#xff0c;选择install 3、打开vscode终端&#x…

【力扣】199.二叉树的右视图

看到这个题目的一瞬间&#xff0c;我想递归&#xff0c;必须用递归。最近被递归折磨的有点狠&#xff0c;但是我感觉我快要打败它了&#xff0c;就是现在稍稍有点处于劣势。不过没关系&#xff0c;来日方长不是。 法一&#xff1a;递归 题解&#xff1a; 之前想的就是先递归&…

2024哪款洗地机最值得入手?热门洗地机推荐

近年来&#xff0c;洗地机的被大家熟悉&#xff0c;越来越多的家庭购置洗地机来清洁家里的卫生&#xff0c;集吸、拖、洗为一体的三重清洁方式&#xff0c;为经常打扫卫生的宝妈脱离了做家务的困境&#xff0c;不用再经历繁琐的清洁步骤(扫地→拖地→拖干)&#xff0c;一拖一拉…

做APP小程序软件开发需要注意哪些细节?

随着移动互联网的快速发展&#xff0c;APP和小程序已成为我们日常生活中不可或缺的一部分。然而&#xff0c;在开发过程中&#xff0c;许多细节常常被忽视&#xff0c;导致用户体验不佳、软件漏洞频发等问题。本文将探讨在APP和小程序开发中需要注意的细节&#xff0c;帮助开发…

华为数通方向HCIP-DataCom H12-831题库(多选题:221-240)

第221题 在割接项目的项目调研阶段需要对现网硬件环境进行观察,主要包括以下哪些内容? A、设备的位置 B、ODF位置 C、接口标识 D、光纤接口对应关系 答案:ABCD 解析: 在项目割接前提的项目调研阶段,需要记录下尽可能详细的信息。 第222题 以下哪些项能被正则表达式10*成…

2024年山东省安全员B证证考试题库及山东省安全员B证试题解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年山东省安全员B证证考试题库及山东省安全员B证试题解析是安全生产模拟考试一点通结合&#xff08;安监局&#xff09;特种作业人员操作证考试大纲和&#xff08;质检局&#xff09;特种设备作业人员上岗证考试大…

SQL server 数据库练习题及答案(练习2)

使用你的名字创建一个数据库 创建表&#xff1a; 数据库中有三张表&#xff0c;分别为student,course,SC&#xff08;即学生表&#xff0c;课程表&#xff0c;选课表&#xff09; 问题&#xff1a; --1.分别查询学生表和学生修课表中的全部数据。--2.查询成绩在70到80分之间…

JBoss JMXInvokerServlet 反序列化漏洞 CVE-2015-7501 已亲自复现

JBoss JMXInvokerServlet 反序列化漏洞 CVE-2015-7501 已亲自复现 漏洞名称漏洞描述影响版本 漏洞复现环境搭建漏洞利用 修复建议总结 漏洞名称 漏洞描述 在Oracle Rapid Planning 12.1/12.2.2中发现了一个被归类为“严重”的漏洞。受到影响的是一些未知的组件处理中间层。升…

【Spark-HDFS小文件合并】使用 Spark 实现 HDFS 小文件合并

【Spark-HDFS小文件合并】使用 Spark 实现 HDFS 小文件合并 1&#xff09;导入依赖2&#xff09;代码实现2.1.HDFSUtils2.2.MergeFilesApplication 需求描述&#xff1a; 1、使用 Spark 做小文件合并压缩处理。 2、实际生产中相关配置、日志、明细可以记录在 Mysql 中。 3、…

JAVA日志

日志 Slf4j slf4j 的全称是 Simple Loging Facade For Java&#xff0c;即它仅仅是一个为 Java 程序提供日志输出的统一接口&#xff0c;并不是一个具体的日志实现方案&#xff0c;就比如 JDBC 一样&#xff0c;只是一种规则而已。所以单独的 slf4j 是不能工作的&#xff0c;…

如何使用 Matplotlib 绘制 3D 圣诞树

系列文章目录 前言 转自&#xff1a;How to draw a 3D Christmas Tree with Matplotlib | by Timur Bakibayev, Ph.D. | Analytics Vidhya | Mediumhttps://medium.com/analytics-vidhya/how-to-draw-a-3d-christmas-tree-with-matplotlib-aabb9bc27864 因为我们把圣诞树安装…

Sql 动态行转列

SELECT ID, Name, [Month],auth FROM dbo.Test3 数据列表&#xff1a; 1.静态行专列 Select auth, MAX( CASE WHEN [Month] 一月 then Name else null end) 一月, MAX( CASE WHEN [Month] 二月 then Name else null end) 二月, MAX( CASE WHEN…

零基础学Java第一天

1.什么是Java Java是一门编程语言 思考问题&#xff1a; 人和人沟通? 中文 英文 人和计算机沟通&#xff1f; 计算机语言&#xff1a; C C C# php python 2. Java诞生 前身叫Oak&#xff08;橡树&#xff09; 目前最流行的版本还是JDK8 3.Java三大平台体系 JavaSE&#xff08…

2312llvm,用匹配器构建clang工具

原文 用LibTooling和LibASTMatchers构建工具 这里展示如何基于Clang的LibTooling构建有用的源到源翻译工具.基础 步骤0:取Clang 因为Clang是LLVM项目的一部分,因此你需要先下载LLVM的源码.Clang和LLVM都在同一个git仓库中,在不同的目录下.更多见入门指南. cd ~/clang-llvm…

(企业 / 公司项目)微服务OpenFeign怎么实现服务间调用?(含面试题)

Feign: 远程调用组件使用步骤&#xff0c;理解上面的图  后台系统中, 微服务和微服务之间的调用可以通过Feign组件来完成.  Feign组件集成了Ribbon负载均衡策略(默认开启的, 使用轮询机制),Hystrix熔断器 (默认关闭的, 需要通过配置文件进行设置开启)  被调用的微服务…

【AI服饰】孔雀背景服装_AIGC服饰订制设计咨询产业

服饰系列 AIGC&#xff08;Artificial Intelligence Generated Content&#xff09;服饰图是指通过人工智能生成的服装设计图案。随着人工智能技术的不断进步&#xff0c;AIGC服饰图在未来有着广阔的发展空间。 首先&#xff0c;AIGC服饰图可以提供更多的设计可能性。传统的服…

TypeScript学习(面试篇)

在当今的 Web 开发世界中&#xff0c;TypeScript 作为一种强大的工具为自己赢得了一席之地&#xff0c;它弥补了 JavaScript 的灵活性和静态类型语言的鲁棒性之间的差距&#xff08;至少在 JavaScript 实现自己的类型之前&#xff09;。 随着技术格局的不断发展&#xff0c;对…

【负载均衡】Keepalived 高可用详解

1、Keepalived介绍 ​ Keepalived是一个基于VRRP协议来实现LVS服务高可用方案,可以利用其来避免单点故障。一个LVS服务会使用2台服务器运行Keepalived,一台为主服务器MASTER,另一台为备份服务器BACKUP,但是对外表现为一个虚拟IP,主服务器会发送特定的消息给备份服务器,当…

NI VeriStand中的硬件I / O延迟时间

NI VeriStand中的硬件I / O延迟时间 - NI 适用于 软件 VeriStand 问题详述 在我的VeriStand项目中&#xff0c;我要从DAQ或FPGA硬件中获取数据&#xff0c;在模型中处理输出&#xff0c;然后输出数据。在硬件输入和输出之间&#xff0c;我应该期望什么样的延迟&#xff1f;如…

工作实践篇 Flink(一:flink提交jar)

一&#xff1a;参数 flink 模式 – standalone 二&#xff1a;步骤 1. 将本地测试好的代码进行本地运行。确保没问题&#xff0c;进行打包。 2. 找到打好的jar包&#xff0c;将jar包上传到对应的服务器。 3. 执行flink命令&#xff0c;跑代码。 /opt/flink/flink-1.13.6/bi…