初窥JQuery(一)jquery选择符 必备知识点


Posted in Javascript onNovember 25, 2010

本章内容根据本人在开发中常用到的选择符作为例子来进行讲解,如有更多常用的简单的例子可回复提供,参与讨论,一起学习研究,首先我们从常用的CSS选择符开始。

CSS选择符包括通配选择符、ID选择符、属性选择符、包含选择符、类选择符等,他们的基本格式为:

通配选择符:$("#ID *") 表示该元素下的所有元素。

ID选择符:$("#ID") 表示获得指定ID的元素。

属性选择符:$("input[type=text]") 表示type属性为text的所有input元素。

包含选择符:$("ul li a") 表示ul元素下所有的li元素里的所有a元素。

类选择符:$(".Class") 表示所有引用Class样式的元素。

当然这些选择符是可以配合使用的比如说:$("#ID input[type=text]"),这种写法表示指定ID元素下的type属性为text的所有input元素。在JQuery中有些细微的改动都是非常有趣的,比如$("ul li").addClass("Class")和$("ul > li").addClass("Class"),他们显示出来的效果是不同的,第一种是将ul下的所有li元素添加样式,第二种是将ul下的第一个li元素添加样式,具体更多的使用方法可以自行测试。

XPath选择符(自1.3版本后已经不支持,但也可了解下)所涵盖的内容不多,他们的基本格式为:

$("[@title]") 表示选择所有元素内 属性带有title的元素。

$("[@title^=t]") 表示所有属性title值是以t为开头的元素。

$("[@title$=t]") 表示所有属性title值是以t为结尾的元素。

  $("[@title*=t]") 表示所有属性title值是包含t的元素。

XPath选择符和CSS选择符一样,也可以配合使用,可以多个XPath选择符一起使用,也可以和CSS选择符一起使用,所以想要达到你想要的要求用JQuery方法是有很多种的。

自定义选择符是选择以一个冒号(:)开头的一种选择符,说到自定义选择符,那就不说到我们经常用到:gt()、:eq()、:odd、:even,这些是我们最常用到的,比如:odd和:even这两个我们通常用他来做有条纹样式的表格,使用方法相当简单,如 $("#table tr:odd").addClass("odd")和$("#table tr:even").addClass("even")只要简单的使用两行代码就可以制作出我们想要的条纹样式。

当然在实际开发中我们一般会使用选择符配合DOM遍历方法来进行操作,如:

$("#table td:contains('Window窗口')").parent().find("td:gt(0)").addClass("highlight")

这句代码表示取得'Window窗口'单元格,再取得他的父级元素,然后找到该元素中包含的所有编号大于0的单元格。当然有些方法是可以简化的,在这里我只是为了表示JQuery的连缀效果,这种格式也是不推荐的,我本人一般是这样书写的:

$("#table td:contains('Window窗口')")
.parent()

//获取父级
.find("td")

 //找到td元素
.not(":contains('Window窗口')")

//不是window窗口的元素
.addClass("highlight");

//添加样式

将他们分开,后面标明,以便于增强可读性。

下面我提供几个在实际开发最常用的代码(由于实在太晚,扛不住了!):

$("input[type='text']").val(''); //清空所有文本框
$("#text input:text").val('');//清空text元素下所有文本框

//获取选中的所有CheckBox的值

$("input:checkbox:checked").each(function() {
alert($(this).val());
});

$("select option:selected").val()//获取选中的下拉框的值

$("select option:selected").text()//获取选中的下拉框的文本

本人对于JQuery选择符的理解到此为止,仅供参考,欢迎感兴趣的朋友参与讨论。未完待续........

demo打包下载

Javascript 相关文章推荐
jquery中获取select选中值的代码
Jun 27 Javascript
从面试题学习Javascript 面向对象(创建对象)
Mar 30 Javascript
使用GruntJS链接与压缩多个JavaScript文件过程详解
Aug 02 Javascript
分享bootstrap学习笔记心得(组件及其属性)
Jan 11 Javascript
微信小程序通过api接口将json数据展现到小程序示例
Jan 20 Javascript
vue实现单选和多选功能
Aug 11 Javascript
es6+angular1.X+webpack 实现按路由功能打包项目的示例
Aug 16 Javascript
通过jquery获取上传文件名称、类型和大小的实现代码
Apr 19 jQuery
promise和co搭配生成器函数方式解决js代码异步流程的比较
May 25 Javascript
微信小程序项目实践之验证码倒计时功能
Jul 18 Javascript
微信上传视频文件提示(推荐)
Nov 22 Javascript
微信小程序登陆注册功能的实现代码
Dec 10 Javascript
初窥JQuery-Jquery简介 入门了解篇
Nov 25 #Javascript
学习并汇集javascript匿名函数
Nov 25 #Javascript
汉化英文版的Dreamweaver CS5并自动提示jquery
Nov 25 #Javascript
XMLHTTPRequest的属性和方法简介
Nov 23 #Javascript
写给想学习Javascript的朋友一点学习经验小结
Nov 23 #Javascript
HTML颜色选择器实现代码
Nov 23 #Javascript
js RuntimeObject() 获取ie里面自定义函数或者属性的集合
Nov 23 #Javascript
You might like
PHP中读写文件实现代码
2011/10/20 PHP
php反射应用示例
2014/02/25 PHP
PHP判断一个数组是另一个数组子集的方法详解
2017/07/31 PHP
Javascript学习笔记8 用JSON做原型
2010/01/11 Javascript
javascript中解析四则运算表达式的算法和示例
2014/08/11 Javascript
前端性能优化及技巧
2016/05/06 Javascript
BootStrap table表格插件自适应固定表头(超好用)
2016/08/24 Javascript
详解Node.js实现301、302重定向服务
2017/04/07 Javascript
Angular.JS中指令ng-if、ng-show/ng-hide和ng-switch的使用教程
2017/05/07 Javascript
Vue.js中兄弟组件之间互相传值实例
2017/06/01 Javascript
详谈Node.js之操作文件系统
2017/08/29 Javascript
详解vue.js之props传递参数
2017/12/12 Javascript
vue实现计步器功能
2019/11/01 Javascript
[42:35]2018DOTA2亚洲邀请赛3月30日 小组赛A组 VG VS OpTic
2018/03/31 DOTA
Python脚本文件打包成可执行文件的方法
2015/06/02 Python
jupyter安装小结
2016/03/13 Python
Jupyter中直接显示Matplotlib的图形方法
2018/05/24 Python
python gensim使用word2vec词向量处理中文语料的方法
2019/07/05 Python
Python异常处理例题整理
2019/07/07 Python
浅谈Python 参数与变量
2020/06/20 Python
python按照list中字典的某key去重的示例代码
2020/10/13 Python
matplotlib 使用 plt.savefig() 输出图片去除旁边的空白区域
2021/01/05 Python
python 实现IP子网计算
2021/02/18 Python
利用CSS3的transition属性实现滑动效果
2015/08/05 HTML / CSS
澳大利亚潮流尖端的快时尚品牌:Cotton On
2016/09/26 全球购物
Melijoe美国官网:法国奢侈童装购物网站
2017/04/19 全球购物
Yahoo-PHP面试题2
2014/12/06 面试题
Internal修饰符有什么含义
2013/07/10 面试题
《狐假虎威》教学反思
2014/02/07 职场文书
办公室文员工作自我鉴定
2014/09/19 职场文书
2014最新股权信托合同协议书
2014/11/18 职场文书
机动车交通事故协议书
2015/01/29 职场文书
师范生见习总结范文
2015/06/23 职场文书
基于python实现银行管理系统
2021/04/20 Python
python自动化之如何利用allure生成测试报告
2021/05/02 Python
Python如何使用循环结构和分支结构
2022/04/13 Python