1.1 jQuery详细介绍
1.1.1 $问题
a) Js命名归法:下划线、字母、$、数字
b) 但是不能以数字作为开头
jQUery的两个变量:$ 和 jQuery
jQuery占用了我们两个变量:$ 和 jQuery
1.1.2 js入口函数跟jQuery入口函数的区别:
- Js的window.onload事件是等到所有内容,以及我们的外部图片之类的文件加载完了之后,才回去执行
- jQuery的入口函数 是在 html所有标签都加载之后,就回去执行。
1.2 Js创建对象
三种方式:
- var obj = {};
- var obj1 = new Object();
- var obj2 = Object.create();
1跟2的区别:
推荐使用第一个方式
第二种方式存在效率问题,因为要new对象,会涉及到原型查找的问题。
1.3 jQuery基本选择器
1.3.1 回顾CSS选择器
CSS选择器回顾 |
||
符号 |
说明 |
用法 |
#id |
Id选择器 |
#id{ color:red; } |
.class |
类选择器 |
.class{ //} |
Element |
标签选择器 |
P { //} |
* |
通配符选择器 |
配合其他选择器来使用 |
, |
并集选择器 |
div,p{} |
空格 |
后代选择器 |
div span{} 选择div下面所有后代的span |
> |
子代选择器 |
div > span{} |
+ |
紧邻选择器 |
div+p 选择div紧挨着的下一个p元素 |
|
1.3.2 jQuery基本选择器
基本选择器 |
||
符号 |
说明 |
用法 |
$(“#demo”) |
选择id为demo的第一个元素 |
$(“#demo”).css(“background”,”red”) |
$(“.liItem”) |
选择所有类名(样式名)为liItem的元素 |
$(“.liItem”). css(“background”,”red”); |
$(“div”) |
选择所有标签名字为div的元素 |
$(“div”). css(“background”,”red”); |
$(“*”) |
选择所有元素 少用或配合其他选择器来使用 |
$(“*”). css(“background”,”red”) |
$(“.liItem,div”) |
选择多个指定的元素,这个地方是选择出了 .liItem元素和div元素 |
$(“.liItem,div”). css(“background”,”red”) |
规律:$(selector).css(“background”,”red”);
1.4 jQuery是什么
jQuery就是javascript的一个库,把我们常用的一些功能进行了封装,方便我们来调用,提高我们的开发效率。
1.4.1 Javascipt跟jQuery的区别:
Javascript是一门编程语言,我们用它来编写客户端浏览器脚本。
jQuery是javascript的一个库,包含多个可重用的函数,用来辅助我们简化javascript开发
jQuery能做的javascipt都能做到,而javascript能做的事情,jQuery不一定能做到。
1.5 jQuery其他选择器
1.5.1 层级选择器
|
||
符号 |
说明 |
用法 |
空格 |
后代选择器 选择所有的后代元素 |
$(“div span”). css(“background”,”red”); |
> |
子代选择器 选择所有的子代元素 |
$(“div > span”). css(“background”,”red”) |
+ |
紧邻选择器 选择紧挨着的下一个元素 |
$(“div + p”). css(“background”,”red”) |
~ |
兄弟选择器 选择后面的所有的兄弟元素 |
$(“div ~ p”). css(“background”,”red”) |
层级选择器选择了选择符 后面那个元素,比如,div > p,是选择>后面的p元素。
1.5.2 过滤选择器
基本过滤选择器 |
||
符号 |
说明 |
用法 |
:eq(index) |
index是从0开始的一个数字,选择序号为index的元素。选择第一个匹配的元素。 |
$(“li:eq(1)”). css(“background”,”red”) |
:gt(index) |
Index 是从0开始的一个数字,选择序号大于index的元素 |
$(“li:gt(2)”). css(“background”,”red”) |
:lt(index) |
Index是从0开始的一个数字,选择小于index 的元素 |
$(“li:lt(2)”). css(“background”,”red”) |
:odd |
选择所有序号为奇数行的元素 |
$(“li:odd”). css(“background”,”red”) |
:even |
选择所有序号为偶数的元素 |
$(“li:even”). css(“background”,”red”) |
:first |
选择匹配第一个元素 |
$(“li:first”). css(“background”,”red”) |
:last |
选择匹配的最后一个元素 |
$(“li:last”). css(“background”,”red”) |
属性选择器 |
||
符号 |
说明 |
用法 |
$(“a[href]”) |
选择所有包含href属性的元素 |
$(“a[href]”). css(“background”,”red”) |
$(“a[href=’itcast’]”) |
选择href属性值为itcast的所有a标签 |
$(“a[href=’itcast’]”). css(“background”,”red”) |
$(“a[href!=’baidu’]”) |
选择所有href属性不等baidu的所有元素,包括没有href的元素 |
$(“a[href!=’baidu’]”). css(“background”,”red”) |
$(“a[href^=’web’]”) |
选择所有以web开头的元素 |
$(“a[href^=’web’]”). css(“background”,”red”) |
$(“a[href$=’cn’]”) |
选择所有以cn结尾的元素 |
$(“a[href$=’cn’]”). css(“background”,”red”) |
$(“a[href*=’i’]”) |
选择所有包含i这个字符的元素,可以是中英文 |
$(“a[href*=’i’]”). css(“background”,”red”) |
$(“a[href][title=’我’]”) |
选择所有符合指定属性规则的元素,都符合才会被选中。 |
$(“a[href][title=’我’]”). css(“background”,”red”) |
筛选选择器参考上课讲的 11 筛选选择器.html
1.6 mouseover事件跟mouseenter事件的区别:
mouseover/mouseout事件,鼠标经过的时候会触发多次,每遇到一个子元素就会触发一次。
mouseenter/mouseleave事件,鼠标经过的时候只会触发一次
1.7 DOM对象跟jQuery对象相互转换
jQuery对象转换成DOM对象:
方式一:$(“#btn”)[0]
方式二:$(“#btn”).get(0)
DOM对象转换成jQuery对象:
$(document) -> 把DOM对象转成了jQuery对象
var btn = document.getElementById(“bt n”);
btn -> $(btn);