初窥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实现tab标签浏览效果
Feb 20 Javascript
一款JavaScript压缩工具:X2JSCompactor
Jun 13 Javascript
jquery动画4.升级版遮罩效果的图片走廊--带自动运行效果
Aug 24 Javascript
yui3的AOP(面向切面编程)和OOP(面向对象编程)
May 01 Javascript
jQuery阻止移动端遮罩层后页面滚动
Mar 15 Javascript
基于Vue2的独立构建与运行时构建的差别(详解)
Dec 06 Javascript
三分钟教你用Node做一个微信哄女友(基友)神器(面向小白)
Jun 21 Javascript
vue 父组件通过v-model接收子组件的值的代码
Oct 27 Javascript
JavaScript仿京东秒杀倒计时
Mar 17 Javascript
如何实现小程序与小程序之间的跳转
Nov 04 Javascript
如何正确解决VuePress本地访问出现资源报错404的问题
Dec 03 Vue.js
Vue.Draggable实现交换位置
Apr 07 Vue.js
初窥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
香妃
2021/03/03 冲泡冲煮
一个PHP数组应该有多大的分析
2009/07/30 PHP
PHP、Nginx、Apache中禁止网页被iframe引用的方法
2020/10/01 PHP
php实现阿拉伯数字和罗马数字相互转换的方法
2015/04/17 PHP
PHP实现获取文件后缀名的几种常用方法
2015/08/08 PHP
详解PHP对象的串行化与反串行化
2016/01/24 PHP
PHP基于自增数据如何生成不重复的随机数示例
2017/05/19 PHP
PHP实现基于回溯法求解迷宫问题的方法详解
2017/08/17 PHP
syntaxhighlighter 使用方法
2007/07/02 Javascript
判断一个对象是否为jquery对象的方法
2014/03/12 Javascript
JS实现无限级网页折叠菜单(类似树形菜单)效果代码
2015/09/17 Javascript
javascript基于prototype实现类似OOP继承的方法
2015/12/16 Javascript
浅谈js多维数组和hash数组定义和使用
2016/07/27 Javascript
jQuery解析XML 详解及方法总结
2016/09/28 Javascript
js实现开启密码大写提示
2016/12/21 Javascript
Angular开发者指南之入门介绍
2017/03/05 Javascript
js防刷新的倒计时代码 js倒计时代码
2017/09/06 Javascript
vue下history模式刷新后404错误解决方法
2018/08/18 Javascript
如何使用vuex实现兄弟组件通信
2018/11/02 Javascript
创建Vue项目以及引入Iview的方法示例
2018/12/03 Javascript
手把手带你封装一个vue component第三方库
2019/02/14 Javascript
Vue侦测相关api的实现方法
2019/05/22 Javascript
vue+element搭建后台小总结 el-dropdown下拉功能
2020/04/10 Javascript
Python编写简单的HTML页面合并脚本
2016/07/11 Python
Python 数据结构之堆栈实例代码
2017/01/22 Python
python dataframe常见操作方法:实现取行、列、切片、统计特征值
2018/06/09 Python
Python使用cx_Freeze库生成msi格式安装文件的方法
2018/07/10 Python
python numpy实现多次循环读取文件 等间隔过滤数据示例
2020/03/14 Python
Pyecharts 动态地图 geo()和map()的安装与用法详解
2020/03/25 Python
解决virtualenv -p python3 venv报错的问题
2021/02/05 Python
建筑施工员岗位职责
2013/11/26 职场文书
职业技术学校毕业生推荐信
2013/12/03 职场文书
升国旗演讲稿
2014/09/05 职场文书
小学数学继续教育研修日志
2015/11/13 职场文书
selenium.webdriver中add_argument方法常用参数表
2021/04/08 Python
Python中的协程(Coroutine)操作模块(greenlet、gevent)
2022/05/30 Python