0


【jQuery从入门到精通】

文章目录

jQuery简介

jQuery是一套兼容多浏览器的javascript脚本库。
核心理念是写得更少,做得更多
使用jQuery将极大的提高编写javascript代码的效率,帮助开发者节省了大量的工作,让写出来的代码更加优雅,更加健壮,“如虎添翼”。同时网络上丰富的jQuery插件也让我们的工作变成了"有了jQuery,一切so easy。"——因为我们已经站在巨人的肩膀上了。

jQuery在2006年1月由美国人John Resig 在纽约的barcamp发布,吸引了来自世界各地的众多JavaScript高手加入,由Dave Methvin率领团队进行开发。如今,jQuery已经成为最流行的javascript框架,在世界前10000个访问最多的网站中,有超过55%在使用jQuery。

jQuery下载与安装

下载

打开jQuery官网,点击Download jQuery按钮。

点击第二个下载开发版:
在这里插入图片描述
打开之后按下

ctrl+s

进行保存即可。
在这里插入图片描述
在这里插入图片描述

版本说明

jQuery 2.x has the same APl as jQuery 1.x, but does not support Internet Explorer 6, 7,or 8.(不支持ie678,如果需要下载1.X)

  1. 完整版:jquery-3.6.0.js -->学习版本(学习源码想高手学习是最好学习方法)
  2. 压缩版:jquery-3.6.0.min.js -->开发版本(压缩版,减少传输)

目前使用版本:

jquery-3.6.0.js

优点

  1. 提供了强大的功能函数
  2. 解决浏览器兼容性问题
  3. 实现丰富的UI和插件
  4. 纠正错误的脚本知识

安装

因为下载的jQuery为一个js文件,安装即在我们的页面引入即可。

<script src="./jquery文件/jquery-3.6.0.js" type="text/javascript"></script>

jQuery核心

$

符号在jQuery 中代表对jQuery对象的引用,**"jQuery"是核心对象**。通过该对象可以获取jQuery对象,调用jQuery提供的方法等。
只有jQuery对象才能调用jQuery提供的方法。
即:

$ <==> jQuery

DOM对象和Jquery包装集对象

明确DOM对象和jQuery包装集的概念,将极大的加快我们的学习速度。原始的DOM对象只有DOM接口提供的方法和属性,通过js代码获取的对象都是DOM对象;而通过jQuery获取的对象是jQuery包装集对象,简称jQuery对象。
只有jQuery对象才能使用jQuery提供的方法。

dom对象的获取

javascript中获取Dom对象,Dom对象只有有限的属性和方法。

通过js通过获取标签(

getElementsByTagName

)的对象为一个伪数组对象。

let dom = document.getElementById('sp1');
console.log(dom);//span#sp1let dom1 =document.getElementsByTagName('sp1');
console.log(dom1);//HTMLCollection(0) []

获取一个不存在的dom对象

通过id查找,返回null。
通过标签查找返回一个空数组。

let dom2 = document.getElementById('sp2');
console.log(dom2);//nulllet dom3 = document.getElementsByTagName('sp2');
console.log(dom3);//HTMLCollection(0) []

jQuery对象的获取

可以说是Dom对象的扩充,在jQuery的世界中将所有的对象,无论是一个还是一组,都封装成一个jQuery包装集,比如获取包含一个元素的jQuery包装集。

通过id选择器来获取对象
使用jQuery获取的对象是一个包装集。

//jquery对象获取let jsd =$("#sp1");
console.log(jsd);//jQuery.fn.init(1) [span#sp1]

获取一个不存在的jQuery对象

通过id选择器查找,返回一个空的包装集对象。

let jsd2 =$("#sp2");
console.log(jsd2);//jQuery.fn.init

DOM对象与jQuery对象的转换

dom对象转jQuery对象

Dom对象转为jQuery对象,只需要利用

$()

方法进行包装即可:

//1.dom=>jquerylet dom = document.getElementById('sp1');
console.log(dom);//span#sp1let dom_jquery =$(dom);
console.log(dom_jquery);//jQuery.fn.init(1)[span#sp1]

jQuery对象转dom对象

jQuery对象转Dom对象,只需要取数组中的元素即可。

let jsd =$("#sp1");
    console.log(jsd);//jQuery.fn.init(1) [span#sp1]let jquery_dom = jsd[0];
    console.log(jquery_dom);//span#sp1

jQuery选择器

和使用js操作Dom一样,获取文档中的节点对象是很频繁的一个操作,在jQuery中提供了简便的方式供我们查找定位元素,称为jQuery选择器,选择器可以说是最考验一个人jQuery功力的地方。
通俗的讲, Selector选择器就是"一个表示特殊语意的字符串"。只要把选择器字符串传入上面的方法中就能够选择不同的Dom对象并且jQuery包装集的形式返回。
jQuery选择器按照功能主要分为"选择"和"过滤"。并且是配合使用的,具体分类如下:

基础选择器

选择器名称举例id选择器#id$(""#testDiv")选择id为testDiv的元素元素名称选择器element$(“div”)选择所有div元素类选择器.class$(".blue")选择所有class=blue的元素选择所有元素*$("*")选择页面所有元素组合选择器selector1,selector2,selectorN$("#testDiv,span,.blue")同时选中多个选择器匹配的元素

实例:

html:

<divid="box1"><divid="box2"><spanclass="sp1">我是span标签</span><pid="blue">蓝色</p></div></div>

jQuery查询:(使用之前记得引入jQuery)

//1.id选择器let box1 =$("#box1");
console.log(box1);//jQuery.fn.init(1) [div#box1]//2.class选择器let class1 =$(".sp1");
console.log(class1);//jQuery.fn.init(1) [span.sp1, prevObject: jQuery.fn.init(1)]//3.元素名称选择器let element1 =$("div");
console.log(element1);//jQuery.fn.init(2) [div#box1, div#box2, prevObject: jQuery.fn.init(1)]//4.选择所有元素let all =$("*");
console.log(all);//jQuery.fn.init(13) [html, head, meta, meta, meta, title, script, body, div#box1, div#box2, span.sp1, p#blue, script, prevObject: jQuery.fn.init(1)]//5.组合选择器let together1 =$("#box1,.sp1,#blue");
console.log(together1);//jQuery.fn.init(3) [div#box1, span.sp1, p#blue, prevObject: jQuery.fn.init(1)]

层次选择器

选择器名称举例后代选择器ancestor descendant$("#parent div")选择id为parent的元素的所有div元素子代选择器parent > child$("#parent>div")选择id为parent的直接div子元素相邻选择器prev + next$(".blue + img")选择css类为blue的下一个img元素同辈选择器prev ~ sibling$(".blue ~ img")选择css类为blue的之后的img元素

实例:

html:

<divid="box1"><divid="box2"><spanclass="sp1">我是span标签</span><pid="blue">蓝色</p></div></div>

jQuery查询:(使用之前记得引入jQuery)

// 1.后代选择器let allChild =$("#box1 *");
console.log(allChild);//jQuery.fn.init(3) [div#box2, span.sp1, p#blue, prevObject: jQuery.fn.init(1)]// 2.子代选择器let childSelect =$("#box2 > *");
console.log(childSelect);//jQuery.fn.init(2) [span.sp1, p#blue, prevObject: jQuery.fn.init(1)]//3.相邻选择器let nextSelect =$(".sp1 + p");
console.log(nextSelect);//jQuery.fn.init(1) [p#blue, prevObject: jQuery.fn.init(1)]// 4.同辈选择器let sameLevel =$(".sp1 ~ *");
console.log(sameLevel);//jQuery.fn.init(1) [p#blue, prevObject: jQuery.fn.init(1)]

表单选择器

选择器名称实例表单选择器:input查找所有的input元素:

$(":input")

,注意:会匹配所有的input、textarea、select和button元素。若加冒号

则只选择

input

标签的表单。文本框选择器:text查找所有文本框:

$(":text")

密码框选择器:password查找所有密码框:

$(":password")

单选按钮选择器:radio查找所有单选按钮:

$(":radio")

复选框选择器:checkbox查找所有复选框:

$(":checkbox")

提交按钮选择器:submit查找所有提交按钮:

$(":submit")

图像域选择器:image查找所有图像域:

$(":image")

重置按钮选择器:reset查找所有重置按钮:

$(":reset")

按钮选择器:button查找所有按钮:

$(":button")

文件域选择器:file查找所有文件域:

$(":file")

这里就不一一演示了,大家可以动手试试。

使用jQuery操作DOM

jQuery也提供了对HTML节点的操作,而且在原生js的基础之上进行了优化,使用起来更加方便。常用的从几个方面来操作:

  1. 查找元素(选择器已经实现)
  2. 创建节点对象
  3. 访问和设置节点对象的值以及属性
  4. 添加节点;
  5. 删除节点;
  6. 删除、添加、修改、设定节点的CSS样式等。

注意:以下的操作方式只适用于jQuery对象。

操作元素属性

属性分类:

  • 固有属性 元素本身具有的属性为固有属性
  • 返回值为boolean类型的属性 checked,selected,disabled
  • 自定义属性 用户自己定义的属性

获取元素属性

方法描述举例attr(属性名称)获取指定的属性值,操作checkbox时,选中返回checked,没有选中返回undefined。attr(‘checked’),attr(‘name’)prop(属性名称)获取具有true和false两个属性的属性值prop(‘checked’)

实例:

html:

<inputtype="checkbox"checked="选中"id="ip1"name="chk1"myself="suliang">男
<inputtype="checkbox"id="ip2"name="chk2">女

jQuery查询获取元素属性:(使用之前记得引入jQuery)

//获取标签let ip1 =$("#ip1");let ip2 =$("#ip2");//1.获取固有元素属性name
console.log(ip1.attr("name"));//chk1
console.log(ip1.prop("name"));//chk2//2.获取返回值为boolean类型的元素属性 checked
console.log(ip1.attr("checked"));//checked
console.log(ip1.prop("checked"));//true//未选中
console.log(ip2.attr("checked"));//undefined
console.log(ip2.prop("checked"));//false//3.选择自定义元素属性
console.log(ip1.attr("myself"));//suliang
console.log(ip1.prop("myself"));//undefined

从上述实例可以看出:

两者区别:

  1. 若是固有属性:attr和prop都返回具体的值
  2. 若是返回值为boolean类型的属性:设置了属性值:attr返回具体的值,prop返回true。没有设置具体的值:attr返回undefined,prop返回false
  3. 若是自定义属性:attr返回具体的值,prop返回undefined

设置元素属性

同样使用attr和prop来进行操作:

语法:

attr("属性名“,"属性值")
prop("属性名","属性值")

实例:

HTML:

<inputtype="checkbox"checked="选中"id="ip1"name="chk1"myself="suliang">男
<inputtype="checkbox"id="ip2"name="chk2">女

jQuery查询设置元素属性:(使用之前记得引入jQuery)

//获取标签let ip1 =$("#ip1");let ip2 =$("#ip2");//1.设置固有元素属性name
ip1.attr("name","su");
console.log(ip1.attr("name"));//su
ip1.prop("name","liang")
console.log(ip1.prop("name"));//liang// //2.设置返回值为boolean类型的元素属性 checked
ip2.attr("checked","checked")
console.log(ip2.attr("checked"));//checked
ip2.prop("checked",true)
console.log(ip2.prop("checked"));//true//3.选择自定义元素属性
ip1.attr("myself1","xiaohu")
console.log(ip1.attr("myself1"));//xiaohu
ip1.prop("myself2","xiaoming")
console.log(ip1.prop("myself2"));//xiaoming 虽然可以显示,但网页源码并无这项属性

从上述实例可以看出:

两者区别:

  1. 若是固有属性:attr和prop都可以进行修改
  2. 若是返回值为boolean类型的属性:两者都可以操作:使用prop操作时,属性值需设置为truefalse
  3. 若是自定义属性:attr可以直接操作,prop操作后网页无显示。

移除元素属性

移除元素属性,我们需要使用remove方法:

语法:

removeAttr("属性名")

实例:

HTML:

<inputtype="checkbox"checked="选中"id="ip1"name="chk1"myself="suliang">男
<inputtype="checkbox"id="ip2"name="chk2">女

jQuery查询移除元素属性:(使用之前记得引入jQuery)

//获取标签let ip1 =$("#ip1");let ip2 =$("#ip2");//移除固有属性和自定义属性
console.log(ip1.attr("name"));//chk1
ip1.removeAttr("name");
console.log(ip1.attr("name"));//undefined

操作元素样式

对元素的样式进行操作,我们可以使用如下方法。
方法说明attr(“class”)获取class属性的值,即样式名称attr(“class”,“样式名”)修改class属性的值,修改样式addClass(“样式名””)添加样式名称css()添加具体的样式removeClass(“class”)移除样式名称
实例:

HTML:

<divclass="box1"><pclass="blue lager">苏凉</p><pclass="pink">刘亦菲</p></div>

jQuery查询操作元素样式:(使用之前记得引入jQuery)

//获取divlet box =$(".box1");//获取p标签let p1 =$(".blue,.lager");let p2 =$(".pink");//1.获取样式名
console.log(p1.attr("class"));//blue lager//2.修改样式值
p2.attr("class","blue");
console.log(p2.attr("class"));//blue//3.添加样式
p2.addClass("lager");
console.log(p2.attr("class"));//blue lager//4.添加具体样式//添加一个
p1.css("color","yellow")//添加多个
p1.css({"font-size":"35px","background-color":"lightblue"});
console.log(p1.attr("style"));//color: yellow; font-size: 35px; background-color: lightblue;//5.移除样式
console.log(p2.attr("class"));//blue lager
p2.removeClass("blue");
console.log(p2.attr("class"));//lager

操作元素内容

方法说明html获取元素的html内容,包含html标签(非表单元素)htm(“html内容”)设定元素的html内容,包含html标签(非表单元素)text()获取元素的文本内容,不包含html标签(非表单元素)text("“text内容”")设置元素的文本内容,不包含html标签(非表单元素)val()获取元素value值(表单元素)val(值’)设定元素的value值(表单元素)
其中前四个方法针对非表单元素,而最后两个针对表单元素:

  • 常见的表单元素: 文本框text、密码框password、单选框radio、复选框checkbox、隐藏域hidden、文本域textarea、下拉框select等可以在页面上操作的元素。
  • 常见的非表单元素: div、span、 h1~h6、 table、tr、 td、p1等

实例:
HTML:

<divid="html">111</div><divid="html2"></div><pid="text"></p><pid="text2"></p><inputtype="text"value="suliang"id="ip1">

jQuery查询修改/获取元素内容:(使用之前记得引入jQuery)

//1.html()修改元素内容,识别html标签,非表单元素//修改内容//带有html标签$("#html").html("<h1>带有html标签(h1)</h1>");//获取let html =$("#html").html();
console.log(html);//<h1>带有html标签(h1)</h1>//不带html标签$("#html2").html("不带html标签");let html2 =$("#html2").html();
console.log(html2);//不带html标签//2.text()修改元素内容,不识别html标签,非表单元素//修改内容$("#text").text("不带html标签");//获取let text =$("#text").text();
console.log(text);//不带html标签// d当修改的内容包含html标签时,页面不识别$("#text2").text("<h1>带有html标签(h1)</h1>");let text2 =$("#text2").text();
console.log(text2);//<h1>带有html标签(h1)</h1>//3.val()获取/修改表单元素的值//获取let value =$("#ip1").val();
console.log(value);//suliang//修改$("#ip1").val("苏凉");let value2 =$("#ip1").val();
console.log(value2);//苏凉

图例:
在这里插入图片描述

创建元素

在jQuery中创建元素很简单,直接使用核心函数即可:

$("创建的元素")
//创建元素let span ="<span>创建一个span元素</span>";
console.log(span);//<span>创建一个span元素</span>// 转换为jQuery对象
console.log($(span));//jQuery.fn.init(1) [span]

添加元素

方法说明prepend(content)在被选元素内部的开头插入元素或内容,被追加的content参数,可以是字符、HTML元素标记。$(content).prependTo(selector)把content元素或内容加入selector元素开头append(content)在被选元素内部的结尾插入元素或内容,被追加的content参数,可以是字符、HTML元素标记。$(content).appendTo(selector)把content元素或内容插入selector元素内,默认是在尾部before()在元素前插入指定的元素或内容:$(selector).before(content)after()在元素后插入指定的元素或内容:$(selector).after(content)
实例:
HTML:

<spanid="ig">IG</span><spanid="edg">EDG</span><divid="rng"><span>gala</span></div>

CSS:

#ig{padding: 5px;background-color: lightblue;}#edg{padding: 5px;background-color: gray;}span{margin: 10px;}#rng{margin-top: 10px;background-color: red;}.fpx{padding: 5px;background-color: lightgreen;}.we{padding: 5px;background-color: lightyellow;}

jQuery查询添加元素:(使用之前记得引入jQuery)

//子级元素追加//前追加 prepend//创建元素let span1 ="<span>ming</span>";let span2 ="<span>xiaohu</span>";// 1指定位置.prepend(内容) $("#rng").prepend(span1);//2.$(内容).prependTo(指定位置)$(span2).prependTo($("#rng"));//后追加 append//创建元素let span3 ="<span>wei</span>";let span4 ="<span>breath</span>";//1.指定位置.append(内容)$("#rng").append(span3);//2.$(内容).appendTo(指定位置)$(span4).appendTo($("#rng"));//同级追加//前追加 before//创建元素let span5 ="<span>FPX</span>";let span6 ="<span>WE</span>";//1.前追加$("#edg").before(span5);$("#ig + span").addClass("fpx");//2.后追加$("#edg").after(span6);$("#edg + span").addClass("we")

图例:
在这里插入图片描述

删除元素

方法说明remove()删除所选元素或指定的子元素,包括整个标签和内容一起删。empty()清空所选元素的内容
实例:

//1.remove() 删除标签和内容$(".green").remove();//2.empty() 删除内容$(".blue").empty();

原图:
在这里插入图片描述
删除了EDG和FPX的标签及内容(

remove()

),删除了RNG和IG的内容(

empty()

)
在这里插入图片描述

遍历元素

  • each() $(selector).each(function(index,element)): 遍历元素参数function为遍历时的回调函数 index为遍历元素的序列号,从0开始。 element是当前的元素,此时是dom元素。

实例:

//遍历元素$("span").each(function(index,element){//索引
    console.log(index);//元素
    console.log(element);//元素
    console.log(this);//转换为jQuery对象
    console.log($(this));})

在这里插入图片描述

注意:用此方法遍历出来的元素为DOM对象,若需要使用jQuery方法,则需要转换为jQuery对象。

jQuery事件

read加载事件

我们知道页面加载是由上而下顺序执行的,当我们将js写在页面头部时,就需要先等页面加载之后js才会生效。

  • 预加载事件
  • 当页面的dom结构加载完毕后执行
  • 类似于js中onload事件
  • ready事件可以写多个

语法:

$(document).read(function(){})

$(function(){})

实例:

<!DOCTYPE html><htmllang="en"><head><metacharset="UTF-8"><metahttp-equiv="X-UA-Compatible"content="IE=edge"><metaname="viewport"content="width=device-width, initial-scale=1.0"><title>Document</title><scriptsrc="./jquery文件/jquery-3.6.0.js"type="text/javascript"></script><script>$(document).ready(function(){
            console.log($("#p1").attr("id"));//p1});//另一种简写$(function(){
            console.log($("#p1").attr("id"));//p1})</script></head><body><pid="p1"></p></body></html>

bind绑定事件

为被选元素添加一个或多个事件处理程序,并规定事件发生时运行的函数。

为元素绑定单个事件

  • 语法: bind绑定:$(元素).bind(事件类型,function(){}) 直接绑定:$(元素).事件类型(function(){})

实例:
HTML:

<buttonid="btn1">按钮一:绑定单个事件(bind绑定)</button><buttonid="btn2">按钮一:绑定单个事件(直接绑定)</button>
//1.绑定单个事件$("#btn1").bind("click",function(){alert("bind绑定!")})$("#btn2").click(function(){alert("直接绑定!")})

为元素绑定多个事件

语法:

  1. 同时为多个事件绑定同一函数:$(元素).bind(事件1 事件2...,function(){})
  2. 为元素绑定多个事件并设置对应函数$(元素).bind(事件1,function(){}).bind(事件2,function(){})
  3. 为元素绑定多个事件并设置对应函数(键值对的形式)$(元素).bind({事件1:function(){},事件2:function(){}})
  4. 为元素直接绑定多个事件并设置对应函数$(元素).事件1(function(){}).事件2(function(){})

实例:
HTML:

<buttonid="btn3">按钮三:绑定多个事件</button><buttonid="btn4">按钮四:绑定多个事件</button><buttonid="btn5">按钮五:绑定多个事件</button><buttonid="btn6">按钮六:绑定多个事件(直接绑定)</button>

jQuery查询绑定元素:(使用之前记得引入jQuery)

// 1.同时为多个事件绑定同一函数`$(元素).bind(事件1 事件2...,function(){})`$("#btn3").bind("click mouseout",function(){alert("为一个元素绑定多个事件!!")})// 2. 为元素绑定多个事件并设置对应函数 `$(元素).bind(事件1,function(){}).bind(事件2,function(){})`$("#btn4").bind('click',function(){alert("被单击了!")}).bind('mouseout',function(){alert("鼠标移开了!")})//3. 为元素绑定多个事件并设置对应函数(键值对的形式) `$(元素).bind({事件1:function(){},事件2:function(){}})`$("#btn5").bind({
    click:function(){alert("被单击了!");},
    mouseout:function(){alert("鼠标移开了!")}})// 4.  为元素直接绑定多个事件并设置对应函数  `$(元素).事件1(function(){}).事件2(function(){})`$("#btn6").click(function(){alert("被单击了!")}).mouseout(function(){alert("鼠标离开了!")})

jQuery Ajax

Ajax即Asynchronous Javascript And XML(异步JavaScript和XML)

  • Ajax 不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的Web应用程序的技术。
  • 使用 JavaScript 向服务器提出请求并处理响应而不阻塞用户核心对象XMLHttpRequest。通过这个对象,您的 JavaScript 可在不重载页面的情况与 Web 服务器交换数据,即在不需要刷新页面的情况下,就可以产生局部刷新的效果。
  • Ajax 在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求),这样就可使网页从服务器请求少量的信息,而不是整个页面。

$.ajax

jquery调用ajax方法:

格式: $.ajax({});

  • 参数:type:请求方式GET/POSTurl:请求地址urlasync:是否异步,默认是true表示异步data:发送到服务器的数据dataType:预期服务器返回的数据类型contentType:设置请求头success:请求成功时调用此函数error:请求失败时调用此函数
$.ajax({
    type:"get",
    url:"file:///D:/HTMLtest/jQuerylearn/js/information.json",
    dataType:"json",
    success:function(data){
        console.log('data');}})

$.get

语法:

$.get("请求地址","请求参数" , function(形参){});

实例:

$.get("js/information.json",{},function(data){
    console.log(data);})

$.post

语法:

$.post("请求地址","请求参数" , function(形参){});
$.post("js/information.json",{},function(data){
    console.log(data);})

$.getJSON

语法:

$.getJSON("请求地址","请求参数" , function(形参){});
$.getJSON("js/information.json",{},function(data){
    console.log(data);})

注: getJSON方式要求返回的数据格式满足json格式(json字符串),若不是json格式,则不返回数据。


本文转载自: https://blog.csdn.net/weixin_46277553/article/details/126085727
版权归原作者 苏凉.py 所有, 如有侵权,请联系我们删除。

“【jQuery从入门到精通】”的评论:

还没有评论