jQuery类库

jQuery介绍

jQuery类库类似python中的模块。

IE浏览器:前端针对iE有时候需要单独写一份代码

  1. jQuery是一个轻量级的、兼容多浏览器的JavaScript库。
  2. jQuery使用户能够更方便地处理HTML Document、Events、实现动画效果、方便地进行Ajax交互,能够极大地简化JavaScript编程。它的宗旨就是:“Write less, do more.“

jQuery优势

  1. 一款轻量级的JS框架。jQuery核心js文件才几十kb,不会影响页面加载速度。(加载速度快
  2. 丰富的DOM选择器,jQuery的选择器用起来很方便,比如要找到某个DOM对象的相邻元素,JS可能要写好几行代码,而jQuery一行代码就搞定了,再比如要将一个表格的隔行变色,jQuery也是一行代码搞定。(选择器更多
  3. 链式表达式。jQuery的链式操作可以把多个操作写在一行代码里,更加简洁。(一行代码走天下
  4. 事件、样式、动画支持。jQuery还简化了js操作css的代码,并且代码的可读性也比js要强。
  5. Ajax操作支持。jQuery简化了AJAX操作,后端只需返回一个JSON格式的字符串就能完成与前端的通信。(重点
  6. 跨浏览器兼容。jQuery基本兼容了现在主流的浏览器,不用再为浏览器的兼容问题而伤透脑筋。
  7. 插件扩展开发。jQuery有着丰富的第三方的插件,例如:树形菜单、日期控件、图片切换插件、弹出窗口等等基本前端页面上的组件都有对应插件,并且用jQuery插件做出来的效果很炫,并且可以根据自己需要去改写和封装插件,简单实用。

jQuery内容

选择器
筛选器
样式操作
文本操作
属性操作
文档处理
事件
动画效果
插件
each、data、Ajax

下载链接:jQuery官网
中文文档:jQuery AP中文文档

jQuery版本

1.x  兼容IE678  最终版本:1.12.4 (2016年5月20日)
2.x  不兼容IE678  最终版本:2.2.4 (2016年5月20日)
3.x  不兼容IE678  目前该版本是官方主要更新维护的版本

jQuery对象

jQuery对象就是通过jQuery包装DOM对象后产生的对象。jQuery对象是 jQuery独有的。

知识补充

准备工作
	1.下载核心文件到本地引入(没有网络也可以使用)
    	<script src="jQuery3.6.js"></script>
 	2.CDN网络资源加载(必须有网络才可以使用)
    前端免费的cdn网站: https://www.bootcdn.cn/
	下载>>官网>>下载>>>min.js
https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.js  //没有压缩
https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.min.js  //压缩
	下载推荐看:https://www.cnblogs.com/goOJBK/p/15890687.html


什么是CDN
	CDN是内容分发网络
	前端免费的cdn网站: https://www.bootcdn.cn/
    
jQuery导入之后需要使用关键字才可以使用
	默认的关键字就是jQuery但是不好输可以用 $ 替换
   jQuery封装了JS代码 让编写更简单 但是有时候JS代码更快(原因要下加载jQuery再加载js代码)
   

js代码与jQuery代码对比

 let pEle = document.getElementsByTagName('p')[0]
    undefined
    pEle.style.color = 'red'
    'red'
    pEle.nextElementSibling.style.color = 'green'

    $('p').first().css('color','yellow').next().css('color','blue')

下面是将jQuery添加到默认环境配置里

image

标签对象与jQuery对象

产生对象
    var $variable = jQuery对像
    var variable = DOM对象
    $variable[0]//jQuery对象转成DOM对象
1.不同的对象能够调用的方法是不同的
	在编写代码的时候一定要看清楚手上是什么对象
2.两者可以互相转换
	标签对象转jQuery对象		
    	$(标签对象)
 	jQuery对象转标签对象
    	jQuery对象[0]

image

jQuery查找标签

1.基本选择器

$('#d1')    id选择器
$('.c1')    class选择器
$('div')    标签选择器

2.组合选择器

$('div#d1')      查找id是d1的div标签
$('span.c1')      查找含有c1样式类的span标签
$('div,span,p')   查找div或者span或者p标签
$('#d1,.c1,span')  查找id是d1的或者class含有c1的或者span标签 
$('*')             查找所有元素选择器

3.层级选择器

$('div p')     查找div里面所有的后代p标签
$('div>p')     查找div里面的儿子p标签
$('div+p')     查找div同级别下面紧挨着的p标签
$('div~p')     查找div同级别下面所有的p标签

4.属性选择器

[attribute]
$('[username]')         查找含有username属性名的标签
$('[username="kimi"]')  查找含有username属性名并且值等于jason的标签
$('input[username="jason"]')

5.基本筛选器

:first // 第一个
:last // 最后一个
:eq(index)// 索引等于index的那个元素
:even // 匹配所有索引值为偶数的元素,从 0 开始计数
:odd // 匹配所有索引值为奇数的元素,从 0 开始计数
:gt(index)// 匹配所有大于给定索引值的元素
:lt(index)// 匹配所有小于给定索引值的元素
:not(元素选择器)// 移除所有满足not条件的标签
:has(元素选择器)// 选取所有包含一个或多个标签在其内的标签(指的是从后代元素找)

$('li:first')   优化   $('li').first()

6.表单筛选器

$(':text')
$(':password')

$(':checked')   checked与selected都会找到的
$(':selected')  selected

7.筛选器方法

$("#id").next()
$("#id").nextAll()
$("#id").nextUntill("#i2")
$("#id").prev()
$("#id").prevAll()
$("#id").prevUtill("#i2")
$("#id").parent()  //查找当前元素的父辈元素
$("#id").parents() //查找当前元素的所有的父辈元素
$("#id").parentsUntil() // 查找当前元素的所有的父辈元素,直到遇到匹配的那个元素为止。
$("#id").children()   // 子类们
$("#id").siblings()  //兄弟们

image-20221207101906054

jQuery的链式操作

将一行代码将第一个p标签变成红色第二个p标签变成绿色
<p>111</p>
<p>222</p

$('p').first().css('color','red').next().css('color','green')

注意:
jQuery对象调用jQuery方法之后返回的还是当前jQuery对象 也就可以继续调用其他方法

python链式操作的本质

class MyClass(object):
    def func1(self):
        print('func1')
        return self
    
    def func2(self):
        print('func2')
        return self
object = MyClass()
obj.func1().func2()

结果:func1  func2

操作标签

1.class操作

jQuery操作            js操作
addClass()			classList.add()
removeClass() 	     classList.remove()
hasClass() 			classList.contains()
toggleClass()		classList.toggle()

2.位置操作

offset()   // 获取匹配元素在当前窗口的相对偏移或设置元素位置
position()  // 获取匹配元素相对父元素的偏移

scrollTop()  // 获取匹配元素相对滚动条顶部的偏移
scrollLeft()  // 获取匹配元素相对滚动条左侧的偏移

eg:
$(window).scrolltop()
$('p').position();
$('p').offset();

3.文本操作

jQuery操作            js操作
text() 				innerText
html()				innerHTML
val()				value
jQuery对象[0].files   files[0]

eg:
<input type="text" id="d1">
<input type="file" id="d2">
    
$('#d1').val()   //获取input框内值
$('#d1').val('520快乐');  //设置input框内值
$('#d2').val()  //获取文件对象
$('#d2')[0].files
$('#d2')[0].files[0]  //正确拿到文件数据

4.创建标签

jQuery操作            js操作
$('<a>')           document.createElement('a')   

5.属性操作

jQuery操作            js操作
attr()               xxxattribute()
removeAttr()         

attr针对动态变化的属性获取会失真,比如性别选择已经默认选择男生,但是我们在浏览器终端里面操作prop,点击女生标签会选中,显示是true,本质应该是false
	prop('checked')  prop('selected')

代码展示1:
<body>
    <input type="text">
    <input type="password">
    <input type="radio">男
    <input type="radio" checked>女
    <input type="radio">其他

    <select name="" id="">
        <option value="">111</option>
        <option value="" selected>222</option>
        <option value="">333</option>
    </select>

    <input type="submit" value="提交">
    <input type="button" value="按钮">
</body>

image

6.文档处理

添加到指定元素内部后面
$(A).append(B)    // 把把B追加到A
$(A).appendTo(B)  // 把A追加到B

添加到指定元素内部的前面
$(A).prepend(B)  // 把B前置到A
$(A).prependTo(B)  // 把A前置到B

添加到指定元素外部的前面
$(A).after(B)  //把B放到A的后面
$(A).insertBefore(B)  //把A放到B的前面

移除何清空元素
remove()   //从DOM中删除所有匹配的元素
empty()   //删除匹配的元素集合中所有的字节点

eg:
1.创建p标签
let $pEle = $('<p>')
2.p标签创建文本
$pEle.text('你好啊')
3.p标签设置属性id名为d1值
$pEle.attr('id','d1')

4.内部尾部追加
$('#d1').append($pEle)  
将变量添加到标签内部
$pEle.appendTo($('#d1'))

jQuery事件

JS绑定事件
	标签对象.on事件名 = function(){}

jQuery事件绑定   
	方式1:
    	jQuery对象.事件名(function(){})
	方式2:
    	jQuery对象.on('事件名称',function(){})

	注意:默认是推荐方式1,不行再用方式2
    
eg1:
    <button id="d1"> 点我</button>
    <script>
        $('#d1').click(function (){
        alert('进来了')
    })

eg2:
    $('#d1').on('click',function (){
      alert('买苹果')
    })


eg3:
    <button >点我</button>
    <button >点我</button>
    <button >点我</button>
    let btnList = document.getElementsByTagName('button');  // []
    for(let i=0;i<btnList.length;i++){
            btnList[i].onclick = function () {
            alert('小样 太简单')
        }
        }

clone****属性

clone(true)  默认不克隆事件   加true就可以

克隆事件

 <button id="d1"> 克隆成功</button>
 <script>
 // 克隆
  $('#d1').on('click',function (){
    // this指代是当前被操作的标签对象 $('#d1')
    console.log(this)  //点击按钮克隆成功,输出台会持续克隆
    $(this).clone().insertAfter($('body'))  //克隆按钮(克隆成功)在浏览器展示,只克隆html,css 不克隆事件
     $(this).clone(true).insertAfter($('body')) //括号内增加true 实现克隆事件
})
</script>


事件相关补充

1.取消后续事件

事件函数的最后加return false 即可
eg:
    <form action="">
        <p>username:
            <input type="text">
        </p>
        <input type="submit" id="d1">
    </form>

    <script>
        $('#d1').click(function (e) {
            alert(123)
            // return false  // 推荐使用
            e.preventDefault()
        })

2.阻止事件冒泡

div包了p包了span

比喻介绍: 当span被点击事件执行->会向上一级p标签汇报自己被点击了 p标签会自己查看是否有点击事件 有则自动执行 在向上一级div标签汇报 div标签也会查看自己是否有点击事件 有则自动执行 该操作叫作 《事件冒泡》

事件函数的最后return false 即可

3.等待页面加载完毕再执行代码

$(function(){})     简写
$(document).ready(function(){})   完整写法

4.事件委托

主要是对动态创建的标签也可以使用绑定的事件
$('body').on('click','button',function(){})
将body内所有的单击事件委托给button标签执行

eg:
    <button>点我</button>

    <script>
        // $('button').click(function () {
        //     alert('速度一定要快!!!')
        // })
        $('body').on('click','button',function () {
            alert('哈哈哈')
        })
    </script>

jQuery动画效果(了解)

1.基本
    show([s,[e],[fn]])
    hide([s,[e],[fn]])
    toggle([s],[e],[fn])
2,滑动
    slideDown([s],[e],[fn])
    slideUp([s,[e],[fn]])
    slideToggle([s],[e],[fn])
3,淡入淡出
    fadeIn([s],[e],[fn])
    fadeOut([s],[e],[fn])
    fadeTo([[s],o,[e],[fn]])
    fadeToggle([s,[e],[fn]])
4.自定义(了解即可)
    animate(p,[s],[e],[fn])

点赞动态展示

<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="x-ua-compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1">
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.js"></script>
  <title>点赞动画示例</title>
  <style>
    div {
      position: relative;
      display: inline-block;
    }
    div>i {
      display: inline-block;
      color: red;
      position: absolute;
      right: -16px;
      top: -5px;
      opacity: 1;
    }
  </style>
</head>
<body>

<div id="d1">点赞</div>

<script>
  $("#d1").on("click", function () {
    var newI = document.createElement("i");
    newI.innerText = "+1";
    $(this).append(newI);
    $(this).children("i").animate({
      opacity: 0
    }, 1000)
  })
</script>
</body>
</html>

页面加载

$('#d1').hide(5000)  // 5秒后 隐藏
w.fn.init [div#d1]
$('#d1').show(5000)  // 5秒后 展示
w.fn.init [div#d1]
           
$('#d1').slideUp(5000) // 往上滑动 
w.fn.init [div#d1]
$('#d1').slideDown(5000)  // 往下滑动
w.fn.init [div#d1]
           
$('#d1').fadeOut(5000)  // 渐变
w.fn.init [div#d1]
$('#d1').fadeIn(5000)  // 渐显
w.fn.init [div#d1]
           
$('#d1').fadeTo(5000,0.4)  // 渐变到某透明度不在变化
w.fn.init [div#d1]   

Bootstrap页面框架

我们要页面搭建的话,直接引入别人写好的css和js,按照规定好的操作方式使用所有的样式和功能。

引入Bootstrap提供的CDN服务

​ 直接引入Bootstrap提供的CDN服务(基于网络直接请求加载) CDN的概念:内容分发网络(加快服务器响应速度,别人可以快速访问到网站的资源) CDN有免费的也有收费的

关于Bootstrap下载

Bootstrap官网下载地址:https://www.bootcss.com/ 选择下载Bootstrap生成环境,关于Bootstrap的版本很多,我们使用v3即可。Bootstrap文件也需要下载,如果不下载Bootstrap的文件,直接引用Bootstrap的的标签,那么在PyCharm敲Bootstrap代码的时候,会不提示Bootstrap相关代码语法 所以先下载Bootstrap文件,在复制Bootstrap标签到HTML文档,添加到PyCharm文档。bootstrap的js代码是依赖于jQuery的,也就意味着你在使用Bootstrap动态效果的时候,一定要导入jQuery
image

文档结构

bootstrap.css
bootstrap.js
注意:js部分是需要依赖于jQuery

CSS标签:
    <link href="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css" >
<script 

JS标签:
src="https://stackpath.bootstrapcdn.com/bootstrap/3.4.1/js/bootstrap.min.js">

pycharm自动提示问题
	最好本地导入几次

核心部分讲解

使用bootstrap其实只需要操作标签的样式类即可

布局容器

class='container'         有留白
class='container-fluid'   没有留白

栅格系统

class = 'row'           一行均分12份
class='col-md-8'    划分一行的12份
    
 栅格偏移
 col-md-offset-3

屏幕参数

col-md-6 col-xs-2 col-sm-3 col-lg-3

重要样式

1.表格样式
	<table class="table table-hover table-striped">
	
	颜色   <tr class="success">
2.表单标签
	class="form-control"
	
3.按钮组
	class="btn btn-primary btn-block"

组件

1.图片
	<span class="glyphicon glyphicon-search" aria-hidden="true"></span>
	图片标签网址:https://fontawesome.com.cn/

2.导航条
	class="navbar navbar-inverse"
3.其他
版权声明:本文为kimi原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/zhanglanhua/p/16963491.html