第一章 jQuery基础

第一章 jQuery基础

jQuery库文件

  • jQuery库分开发版和发布版

    • | 名称 | 大小 | 说 明 |
      | -------------------------------- | -------- | ------------------------------------------------------------ |
      | jquery-3.版本号.js(开发版) | 约286KB | 完整无压缩版本,主要用于测试、学习和开发 |
      | jquery-3.版本号.min.js(发布版) | 约94.8KB | 经过工具压缩或经过服务器开启Gzip压缩,主要应用于发布的产品和项目 |
  • 在页面中引入jQuery

    • <script src="js/jquery-3.3.1.min.js" type="text/javascript"></script>
      

jQuery基本语法

  • 使用jQuery弹出提示框
<script>
     $(document).ready(function() {		//为页面加载事件绑定方法
        alert("我欲奔赴沙场征战jQuery,势必攻克之!");
    });
</script>

$(document).ready()

  • $(document).ready()与window.onload类似,但也有区别
window.onload $(document).ready()
执行时机 必须等待网页中所有的内容加载完毕后(包括图片、flash、视频等)才能执行 网页中所有DOM文档结构绘制完毕后即刻执行,可能与DOM元素关联的内容(图片、flash、视频等)并没有加载完
编写个数 同一页面不能同时编写多个 同一页面能同时编写多个
简化写法 $(function(){ //执行代码 }) ;

jQuery选择器

  • jQuery 语法
    • jQuery 语法是为 HTML 元素的选取编制的,可以对元素执行某些操作
    • 基础语法是:$(selector).action()

jQuery基本选择器

  • 基本选择器包括标签选择器、类选择器、ID选择器、并集选择器和全局选择器
名称 语法构成 描述 示例
标签选择器 element 根据给定的标签名匹配元素 $(“h2” )选取所有h2元素
类选择器 .class 根据给定的class匹配元素 $(" .title")选取所有class为title的元素
ID选择器 #id 根据给定的id匹配元素 $(" #title")选取id为title的元素
并集选择器 selector1,selector2,…,selectorN 将每一个选择器匹配的元素合并后一起返回 $(“div,p,.title” )选取所有div、p和拥有class为title的元素
全局选择器 * 匹配所有元素 $(“*” )选取所有元素

标签选择器

  • 标签选择器根据给定的标签名匹配元素
$(document).ready(function(){
    $("dt").click(function(){
        $("dd").css("display","block"); 	//设置<dd>标签中的内容显示出来

    });
    $("h1").css("color","blue");	//设置<h1>标签中的字体颜色为蓝色
})

类选择器

  • 类选择器根据给定的class匹配元素
$(".price").css({"background":"#efefef","padding":"5px"}); //设置class为price元素的背景颜色和内边距

ID选择器

$("#author").css("color","#083499");	//设置id为author的元素的字体颜色

并集选择器

  • 并集选择器用来合并元素集合
$(".intro,dt,dd").css("color","#ff0000");

全局选择器

  • 全局选择器可以获取所有元素
$("*").css("font-weight","bold");	//设置所有元素的字体加粗显示

jQuery层次选择器

  • 层次选择器通过DOM 元素之间的层次关系来获取元素
名称 语法构成 描述 示例
后代选择器 ancestor descendant 选取ancestor元素里的所有descendant(后代)元素 $(“#menu span” )选取#menu下的元素
子选择器 parent>child 选取parent元素下的child(子)元素 $(“#menu>span” )选取#menu的子元素
相邻元素选择器 prev+next 选取紧邻prev元素之后的next元素 $(" h2+dl " )选取紧邻元素之后的同辈元素
同辈元素选择器 prev~sibings 选取prev元素之后的所有siblings元素 $(" h2~dl " )选取元素之后所有的同辈元素

后代选择器

  • 后代选择器用来获取元素的后代元素
$(".textRight p").css("color","red");	//设置class为textRight元素中的所有<p>标签的字体全部为红色

子选择器

  • 子选择器用来获取元素的元素
$(".textRight>p").css("color","red");

相邻选择器

  • 相邻选择器用来选取紧邻目标元素的下一个元素
$("h1+p").css(text-decoration","underline"); 

同辈选择器

  • 同辈选择器用来选取目标元素之后的所有同辈元素
$("h1~p").css("text-decoration","underline");

jQuery属性选择器

  • 属性选择器通过HTML元素的属性来选择元素
语法构成 描述 示例
[attribute^=value] 选取给定属性是以某些特定值开始的元素 $(" [href^=‘en’]" )选取href属性值以en开头的元素
[attribute$=value] 选取给定属性是以某些特定值结尾的元素 ( " [ h r e f (" [href ("[href=‘.jpg’]" )选取href属性值以.jpg结尾的元素
[attribute*=value] 选取给定属性是以包含某些值的元素 $(" [href* =‘txt’]" )选取href属性值中含有txt的元素

根据属性名获取元素

  • 属性选择器可以根据是否包含某属性来选取元素
    • a标签带有class属性
$("#news a[class]").css("background","#c9cbcb");

根据属性值获取元素

  • 属性选择器可以根据属性的值来选取元素
    • class属性值为hot
$("#news a[class='hot']").css("background","#c9cbcb");
  • 属性选择器可以指定选取不等于属性是某个特定值的元素
    • class值不等于hot
$("#news a[class!='hot']").css("background","#c9cbcb");

根据属性值包含特定的值获取元素

  • 属性选择器可以指定属性值以指定值开头的元素
    • a标签href属性值以www开头
$("#news a[href^='www']").css("background","#c9cbcb");
  • 属性选择器可以指定属性值以指定值结尾的元素
    • a标签href属性值以html结尾
$("#news a[href$='html']").css("background","#c9cbcb");
  • 属性选择器可以指定属性值包含指定值的元素
    • a标签href属性值包含“k2”的元素
$("#news a[href*='k2']").css("background","#c9cbcb");

过滤选择器

  • 通过特定的过滤规则来筛选出所需的元素
  • 主要分类
    • 基本过滤选择器
    • 可见性过滤选择器
    • 表单对象过滤选择器
    • 内容过滤选择器、子元素过滤选择器……

基本过滤选择器

语法 描述 示例
:first 选取第一个元素 $(" li:first" )选取所有元素中的第一个元素
:last 选取最后一个元素 $(" li:last" )选取所有元素中的最后一个元素
:not(selector) 选取去除所有与给定选择器匹配的元素 $(" li:not(.three)" )选取class不是three的元素
:even 选取索引是偶数的所有元素(index从0开始) $(" li:even" )选取索引是偶数的所有元素
:odd 选取索引是奇数的所有元素(index从0开始) $(" li:odd" )选取索引是奇数的所有元素
语法 描述 示例
:eq(index) 选取索引等于index的元素(index从0开始) $(“li:eq(1)” )选取索引等于1的元素
:gt(index) 选取索引大于index的元素(index从0开始) $(" li:gt(1)" )选取索引大于1的元素(注:大于1,不包括1)
:lt(index) 选取索引小于index的元素(index从0开始) $(“li:lt(1)” )选取索引小于1的元素(注:小于1,不包括1)
:header 选取所有标题元素,如h1~h6 $(“:header” )选取网页中所有标题元素
:focus 选取当前获取焦点的元素 $(“:focus” )选取当前获取焦点的元素
:animated 选择所有动画 $(“:animated” )选取当前所有动画元素

可见性过滤选择器

语法 描述 示例
:visible 选取所有可见的元素 $(“:visible” )选取所有可见的元素
:hidden 选取所有隐藏的元素 $(“:hidden” ) 选取所有隐藏的元素
$("p:hidden").show();
$("p:visible").hide();

jQuery选择器注意事项

1、特殊符号的转义

<div id="id#a">aa</div>
<div id="id[2]">cc</div>
  • 获取这两个元素的选择器
//错误获取方法
$("#id#a");
$("#id[2]");

//正确获取方法
$("#id\\#a");
$("#id\\[2\\]");

2、选择器中的空格

  • 选择器的书写规范很严格,多一个空格或少一个空格,都会影响选择器的效果
//选取class为“test”的元素内部的隐藏元素
var $t_a = $(".test :hidden"); //带空格的jQuery选择器

//选取隐藏的class为“test”的元素
var $t_b = $(".test:hidden");  //不带空格的jQuery选择器

相关文章

学习编程是顺着互联网的发展潮流,是一件好事。新手如何学习...
IT行业是什么工作做什么?IT行业的工作有:产品策划类、页面...
女生学Java好就业吗?女生适合学Java编程吗?目前有不少女生...
Can’t connect to local MySQL server through socket \'/v...
oracle基本命令 一、登录操作 1.管理员登录 # 管理员登录 ...
一、背景 因为项目中需要通北京网络,所以需要连vpn,但是服...