下载链接:jQuery官网
中文文档:jQuery AP中文文档
维护IE678是一件让人头疼的事情,一般我们都会额外加载一个CSS和JS单独处理。值得庆幸的是使用这些浏览器的人也逐步减少,PC端用户已经逐步被移动端用户所取代,如果没有特殊要求的话,一般都会选择放弃对678的支持。
jQuery对象就是通过jQuery包装DOM对象后产生的对象。jQuery对象是 jQuery独有的。如果一个对象是 jQuery对象,那么它就可以使用jQuery里的方法:例如$(“#i1”).html()。
$("#i1").html()
的意思是:获取id值为 i1
的元素的html代码。其中 html()
是jQuery里的方法。
相当于: document.getElementById("i1").innerHTML;
虽然 jQuery对象
是包装 DOM对象
后产生的,但是 jQuery对象
无法使用 DOM对象
的任何方法,同理 DOM对象
也没不能使用 jQuery
里的方法。
一个约定,我们在声明一个jQuery对象变量的时候在变量名前面加上$:
var $variable = jQuery对象 var variable = DOM对象 $variable[0] //jQuery对象转成DOM对象
拿上面那个例子举例,jQuery对象和DOM对象的使用:
$("#i1").html(); //jQuery对象可以使用jQuery的方法 $("#i1")[0].innerHTML; //DOM对象使用DOM的方法
$(selector).action()
ID选择器:
$("#id")
标签选择器:
$("tagName")
class选择器:
$(".className")
配合使用:
$("div.c1") // 找到有c1 class类的div标签
所有元素选择器:
$("*")
组合选择器:
$("#id, .className, tagName")
x 和 y 可以为任意选择器
$("x y"); // x的所有后代y(子子孙孙) $("x > y"); // x的所有儿子y(儿子) $("x + y"); // 找到所有紧挨在x后面的y $("x ~ y"); // x之后所有的兄弟y
[attribute] // 属性 [attribute=value] // 属性等于 [attribute!=value] // 属性不等于
例子:
<input type="text"> <input type="password"> <input type="checkbox">
$("input[type=‘checkbox‘]"); // 取到checkbox类型的input标签 $("input[type!=‘text‘]"); // 取到类型不是text的input标签
:first // 第一个 :last // 最后一个 :eq(index) // 匹配等于给定索引值的那个元素 :gt(index) // 匹配所有大于给定索引值的元素 :lt(index) // 匹配所有小于给定索引值的元素 :even // 匹配所有索引值为偶数的元素,从 0 开始计数 :odd // 匹配所有索引值为奇数的元素,从 0 开始计数 :not(元素选择器) // 移除所有满足not条件的标签 :has(元素选择器) // 选取所有包含一个或多个标签在其内的标签(指的是从后代元素找)
例子:
$("div:has(h1)") // 找到所有后代中有h1标签的div标签 $("div:has(.c1)") // 找到所有后代中有c1样式类的div标签 $("li:not(.c1)") // 找到所有不包含c1样式类的li标签 $("li:not(:has(a))") // 找到所有后代中不含a标签的li标签
练习:
自定义模态框,使用jQuery实现弹出和隐藏功能。
:text // 筛选出所有的单行输入文本 :password // 筛选出所有的密码输入框 :file // 筛选出所有的文本选择框 :radio // 筛选出所有的单选框 :checkbox // 筛选出所有的多选框 :submit // 筛选出所有的提交按钮 :reset // 筛选出所有的重置按钮 :button // 筛选出所有的普通按钮
例子:
$(":checkbox") // 找到所有的checkbox
表单对象属性:
:enabled // 筛选出所有可用元素 :disabled // 筛选出所有不可用元素 :checked // 筛选出所有被选中的(单选框,复选框) :selected // 筛选出所有被选中的选项列表
例子:
找到可用的input标签
<form> <input name="email" disabled="disabled" /> <input name="id" /> </form> $("input:enabled") // 找到可用的input标签
找到被选中的option:
<select id="s1"> <option value="beijing">北京市</option> <option value="shanghai">上海市</option> <option selected value="guangzhou">广州市</option> <option value="shenzhen">深圳市</option> </select> $(":selected") // 找到所有被选中的option
下一个元素:
$("#id").next() // 查找当前元素的下一个元素 $("#id").nextAll() // 查找当前元素的下面所有元素 $("#id").nextUntil("#i2") // 查找当前元素的到ID为i2中的所有元素
上一个元素:
$("#id").prev() // 查找当前元素的上一个元素 $("#id").prevAll() // 查找当前元素的上面所有元素 $("#id").prevUntil("#i2") // 查找ID为i2到当前元素中的所有元素
父亲元素:
$("#id").parent() // 查找当前元素的父辈元素 $("#id").parents() // 查找当前元素的所有的父辈元素 $("#id").parentsUntil() // 查找当前元素的所有的父辈元素,直到遇到匹配的那个元素为止。
儿子和兄弟元素:
$("#id").children(); // 儿子们 $("#id").siblings(); // 兄弟们
查找
搜索所有与指定表达式匹配的元素。这个函数是找出正在处理的元素的后代元素的好方法。
$("div").find("p")
等价于$("div p")
筛选
筛选出与指定表达式匹配的元素集合。这个方法用于缩小匹配的范围。用逗号分隔多个表达式。
$("div").filter(".c1") // 从结果集中过滤出有c1样式类的
等价于 $("div.c1")
补充:
.first() // 获取匹配的第一个元素 .last() // 获取匹配的最后一个元素 .not() // 从匹配元素的集合中删除与指定表达式匹配的元素 .has() // 保留包含特定后代的元素,去掉那些不含有指定后代的元素。 .eq() // 索引值等于指定值的元素
原文:https://www.cnblogs.com/zyling/p/12075020.html