jQuery温习篇 强大的JQuery选择器


Posted in Javascript onApril 24, 2010

在jQuery出世以来,它取得很大的成就和认同。JQuery是一个轻量级的JavaScript框架,它的发布版很小仅16K左右。它能让你方便简洁的写出漂亮的动画效果、实现各种视觉效果,轻松的处理JavaScript的DOM数以及Ajax的交互行为。它的优点在于轻量级、简单易学、易扩展、跨浏览器和网上拥有大量的jQuery插件使用。由于它这一大堆的优点,它已经被微软官方认可加入VS IDE中拥有强大的智能提示,并据官方的统计现在至少有20%的国际性大网站已经加入jQuery作为其脚本。

1:首先是JavaScript的DOM 和 jQuery包装集的区分


1.1:在JavaScript中我们访问的方式是操作DOM结构,提供的可用方法有:

1: document.getElementById("ID"):根据ID获取DOM对象。

2:document.getElementsByName("name"):根据HTML标记name属性获取一个DOM数组。

3:document.getElementsByTagName("Tag"):根据HTML的Tag获取一个DOM数组。

1.2:jQuery相对DOM则提供了许多可用的方法和属性。

jQuery简单的获取对象有$(“#id”) ,$(“.class”),$(“tag”)方式,它的书写方式和css3.0相似 id用#,class(css)用.,HTMl Tag则直接书写。关于jquery的选择器在下面讲述,这里不急。         

1.3:JavaScript的DOM对象转可以化为jQuery包装集:通过$(element)赴会就为jQuery包装集。

 

2:jQuery最强大的就是提供了一个万能的属性选择器。


2.1基本选择器
选择表达式 说明 举例
#id 根据给定的ID匹配一个元素用# $("#testDiv2")  获取ID为testDiv2的元素
.class 根据给定的类匹配元素(也就是取class的值)用. $(".myDiv")    获取class为myDiv的一组元素
element 根据给定的元素名匹配所有元素,直接写上元素名例如(p,a,input,div等) $("div")    获取所有的div元素
selector1,selector2,selectorN 将每一个选择器匹配到的元素合并后一起返回,选择器可以是id,class,element用,隔开 $("#testDiv2,p") $("p,span,div.myDiv") 获取所有的p,span和class为myDiv的元素
* 选择所有的元素 $("*")

2.2简单选择器

选择表达式 说明 举例
:first 匹配找到的第一个元素 $("div:first")
:last 匹配找到的最后一个元素 $("div:last")
:eq(index) 匹配一个给定索引值的元素,当然要存在才可以找得到,索引从0开始 $("div:eq(1)")
:gt(index) 匹配所有大于给定索引值的元素 $("div:gt(0)")    查找第1个以后的元素
:lt(index) 匹配所有小于给定索引值的元素 $("div:lt(2)")     查找第一行和第二行的元素
:even 匹配所有索引值为偶数的元素,从 0 开始计数 $("div:even") 查找第1,3,5个div
:odd 匹配所有索引值为奇数的元素,从 0 开始计数 $("div:odd") 查找第2,4个div
:not(selector) 去除所有与给定选择器匹配的元素selector为表达式,可以是属性里面的一个值 $("input:not(:checked)") 查找所有未选中的input 元素[注 :checked为自定义筛选选择器,后面会讲到]
:header 匹配如 h1, h2, h3之类的标题元素 $(":header").css("background", "#EEE"); 添加样式
:animated 匹配所有正在执行动画效果的元素 暂无例子

3.3:内容选择器

选择表达式 说明 举例
:contains(text) 匹配包含给定文本的元素,只要里面出现即可 $("p:contains('段落')") 找带有段落字样的p元素
:empty 匹配所有不包含子元素或者文本的空元素 $("div:empty")
:has(selector) 匹配含有选择器所匹配的元素的元素 $("div:has('p')")
:parent 匹配含有子元素或者文本的元素 $("div:parent")

 

4.4子元素选择器

选择器 说明 举例
:first-child 匹配第一个子元素 $("ul li:first-child")//在每个 ul 中查找第一个 li
:last-child 匹配最后一个子元素 $("ul li:last-child")//在每个 ul 中查找最后一个 li
:nth-child(index/even/odd/equation) 匹配其父元素下的第N个子或奇偶元素 ':eq(index)' 只匹配一个元素,而这个将为每一个父元素匹配子元素。:nth-child从1开始的,而:eq()是从0算起的! 可以使用:nth-child(even)//偶数行:nth-child(odd)//奇数行:nth-child(3n):nth-child(2)//索引为2的:nth-child(3n+1):nth-child(3n+2) $("ul li:nth-child(2)")//在每个 ul 查找第 2 个li
:nth-child(index/even/odd/equation) 匹配其父元素下的第N个子或奇偶元素 $("ul li:nth-child(2)")//在每个 ul 查找第 2 个li
:only-child 如果某个元素是父元素中唯一的子元素,那将会被匹配 如果父元素中含有其他元素,那将不会被匹配。 $("ul li:only-child")//在 ul 中查找是唯一子元素的 li

4.5:可见性选择器

选择器 说明 举例
:hidden 匹配所有的不可见元素,input 元素的 type 属性为 "hidden" 的话也会被匹配到 $("div:hidden")
:visible 匹配所有的可见元素 $("div:visible")//元素来匹配$(".divH:visible")//根据class来匹配

例子就不用多讲了,大家对于jQuery应该都有一定的见地了。呵呵…

Javascript 相关文章推荐
ASP SQL防注入的方法
Dec 25 Javascript
jQuery的实现原理的模拟代码 -1 核心部分
Aug 01 Javascript
分页栏的web标准实现
Nov 01 Javascript
Javascript 实现的数独解题算法网页实例
Oct 15 Javascript
网页右侧悬浮滚动在线qq客服代码示例
Apr 28 Javascript
JavaScript设置表单上传时文件个数的方法
Aug 11 Javascript
AngularJS中的Directive实现延迟加载
Jan 25 Javascript
WEB前端开发框架Bootstrap3 VS Foundation5
May 16 Javascript
SpringMVC+bootstrap table实例详解
Jun 02 Javascript
微信小程序之页面跳转和参数传递的实现
Sep 29 Javascript
JS函数节流和函数防抖问题分析
Dec 18 Javascript
JavaScript遍历DOM元素的常见方式示例
Feb 16 Javascript
javascript 二分法(数组array)
Apr 24 #Javascript
JS判断是否为数字,是否为整数,是否为浮点数的代码
Apr 24 #Javascript
JavaScript 比较时间大小的代码
Apr 24 #Javascript
google 搜索框添加关键字实现代码
Apr 24 #Javascript
javascript XMLHttpRequest对象全面剖析
Apr 24 #Javascript
javascript之AJAX框架使用说明
Apr 24 #Javascript
基于jquery的一个图片hover的插件
Apr 24 #Javascript
You might like
php+mysql查询优化简单实例
2015/01/13 PHP
PHP获取某个月最大天数(最后一天)的方法
2015/07/29 PHP
浅析PHP中的i++与++i的区别及效率
2016/06/15 PHP
PHP join()函数用法与实例讲解
2019/03/11 PHP
thinkphp5 框架结合plupload实现图片批量上传功能示例
2020/04/04 PHP
javascript 选择文件夹对话框(web)
2009/07/07 Javascript
jQuery 操作下拉列表框实现代码
2010/02/22 Javascript
jquery的$getjson调用并获取远程的JSON字符串问题
2012/12/10 Javascript
Javascript 按位与运算符 (&)使用介绍
2014/02/04 Javascript
QQ空间顶部折页撕开效果示例代码
2014/06/15 Javascript
javascript原始值和对象引用实例分析
2015/04/25 Javascript
javascript中setAttribute()函数使用方法及兼容性
2015/07/19 Javascript
浅析jQuery移动开发中内联按钮和分组按钮的编写
2015/12/04 Javascript
轻量级jQuery插件slideBox实现带底栏轮播(焦点图)代码
2016/03/28 Javascript
javascript 用函数实现继承详解
2016/05/28 Javascript
JS/jQ实现免费获取手机验证码倒计时效果
2016/06/13 Javascript
详解webpack提取第三方库的正确姿势
2017/12/22 Javascript
解决vue页面DOM操作不生效的问题
2018/03/17 Javascript
详解easyui基于 layui.laydate日期扩展组件
2018/07/18 Javascript
JS学习笔记之贪吃蛇小游戏demo实例详解
2019/05/29 Javascript
基于layui实现高级搜索(筛选)功能
2019/07/26 Javascript
Nodejs + sequelize 实现增删改查操作
2020/11/07 NodeJs
JS实现简易日历效果
2021/01/25 Javascript
Django admin美化插件suit使用示例
2017/12/12 Python
python 产生token及token验证的方法
2018/12/26 Python
django迁移文件migrations的实现
2020/03/31 Python
python与js主要区别点总结
2020/09/13 Python
洛佩桑酒店官方网站:Lopesan Hotels
2019/04/15 全球购物
售后主管岗位职责
2013/12/08 职场文书
团队队名口号大全
2014/06/06 职场文书
购房协议书范本
2014/10/02 职场文书
应届毕业生求职信范文
2015/03/19 职场文书
走进科学观后感
2015/06/18 职场文书
患者身份识别制度
2015/08/06 职场文书
坚持不是死撑,更重要的是心态
2019/08/19 职场文书
纯html+css实现Element loading效果
2021/08/02 HTML / CSS