初窥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 相关文章推荐
解决js数据包含加号+通过ajax传到后台时出现连接错误
Aug 01 Javascript
完美解决IE低版本不支持call与apply的问题
Dec 05 Javascript
一个不错的js html页面倒计时可精确到秒
Oct 22 Javascript
原生javascript实现隔行换色
Jan 04 Javascript
C#中使用迭代器处理等待任务
Jul 13 Javascript
jQuery+formdata实现上传进度特效遇到的问题
Feb 24 Javascript
原生js实现addClass,removeClass,hasClass方法
Apr 27 Javascript
bootstrap timepicker在angular中取值并转化为时间戳
Jun 13 Javascript
JavaScript数组push方法使用注意事项
Oct 30 Javascript
了解JavaScript表单操作和表单域
May 27 Javascript
基于JavaScript获取base64图片大小
Oct 18 Javascript
如何在现代JavaScript中编写异步任务
Jan 31 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
收音机怀古---春雷3P7图片欣赏
2021/03/02 无线电
PHP include任意文件或URL介绍
2014/04/29 PHP
destoon整合UCenter图文教程
2014/06/21 PHP
PHP实现简单计算器小程序
2020/08/28 PHP
php 使用ActiveMQ发送消息,与处理消息操作示例
2020/02/23 PHP
JavaScript XML实现两级级联下拉列表
2008/11/10 Javascript
jquery 笔记 事件
2011/11/02 Javascript
javascript实例--教你实现扑克牌洗牌功能
2014/05/15 Javascript
javascript框架设计之浏览器的嗅探和特征侦测
2015/06/23 Javascript
js实现超酷的照片墙展示效果图附源码下载
2015/10/08 Javascript
javascript常用经典算法实例详解
2015/11/25 Javascript
node模块机制与异步处理详解
2016/03/13 Javascript
Webpack执行命令参数详解
2017/06/17 Javascript
node.js中使用Export和Import的方法
2017/09/18 Javascript
详解基于vue-router的动态权限控制实现方案
2017/09/28 Javascript
解决vue中使用swiper插件问题及swiper在vue中的用法
2018/04/04 Javascript
微信小程序中的canvas 文字断行和省略号显示功能的处理方法
2018/11/14 Javascript
vue项目中全局引入1个.scss文件的问题解决
2019/08/01 Javascript
解决vue项目刷新后,导航菜单高亮显示的位置不对问题
2019/11/01 Javascript
vue微信分享插件使用方法详解
2020/02/18 Javascript
跟老齐学Python之有点简约的元组
2014/09/24 Python
Django查找网站项目根目录和对正则表达式的支持
2015/07/15 Python
通过python改变图片特定区域的颜色详解
2019/07/15 Python
python中多个装饰器的调用顺序详解
2019/07/16 Python
Python绘制三角函数图(sin\cos\tan)并标注特定范围的例子
2019/12/04 Python
Python进程间通信multiprocess代码实例
2020/03/18 Python
html5构建触屏网站之touch事件介绍
2013/01/07 HTML / CSS
英国天然有机美容护肤品:Neal’s Yard Remedies
2018/05/05 全球购物
Yummie官方网站:塑身衣和衣柜必需品
2019/10/29 全球购物
师德师风自我剖析材料
2014/09/27 职场文书
学雷锋日活动总结
2015/02/06 职场文书
2015年银行员工工作总结
2015/04/24 职场文书
为什么说餐饮很难做,是因为你不了解这些新规则
2019/08/20 职场文书
Nginx服务器添加Systemd自定义服务过程解析
2021/03/31 Servers
MySQL REVOKE实现删除用户权限
2021/06/18 MySQL
Nginx设置HTTPS的方法步骤 443证书配置方法
2022/03/21 Servers