JQuery选择器、过滤器大整理


Posted in Javascript onMay 26, 2015

经过一晚上的查找整理,终于整理出一套应该算最全面的JQuery选择过滤器的方法了。所有代码均经过测试。

首先HTML代码

HTML Code
<html>

<head>

<script type="text/javascript" src="JQuery/jquery-1.5.1.js"></script>

</head>

<body>

<form name="form1" id="form1" class="form1" action="" method="post">
  <table name="table1" id="table1" class="table1">

    <tr name="tr1" id="tr1" class="tr1">

      <td name="td11" id="td11" class="td11" nowrap>

      <input type="text" name="text11" id="text11" class="text11" value="text11"/>

      <input type="button" name="button11" id="button11" class="button11" value="button11"/>

      </td>

      <td name="td12" id="td12" class="td12">

      <input type="text" name="text12" id="text12" class="text12" value="text12"/>

      <input type="hidden" name="hidden12" id="hidden12" class="hidden12" value="hidden12"/>

      </td>

      <td name="td13" id="td13" class="td13">

      <input type="text" name="text13" id="text13" class="text13" value="text13"/>

      </td>

    </tr>

    <tr name="tr2" id="tr2" class="tr2">

      <td name="td21" id="td21" class="td21">

      <input type="password" name="password21" id="password21" class="password21" value="password21"/>

      <input type="radio" name="radio21" id="radio21" class="radio21" value="radio21" checked/>

      <input type="checkbox" name="checkbox21" id="checkbox21" class="checkbox21" value="checkbox21" checked/>

      </td>

      <td name="td22" id="td22" class="td22" nowrap>

      <input type="submit" name="submit22" id="submit22" class="submit22" value="submit22"/>

      <input type="image" name="image22" id="image22" class="image22" value="image22"/>

      <input type="reset" name="reset22" id="reset22" class="reset22" value="reset22"/>

      </td>

      <td name="td23" id="td23" class="td23">

      <input type="file" name="file23" id="file23" class="file23" value="file23"/>

      </td>

    </tr>

    <tr name="tr3" id="tr3" class="tr3">

      <td name="td31" id="td31" class="td31">
  <select name="select31" size="1">

    <option value="select311">option1</option>

    <option value="select312" selected>option2</option>

    <option value="select313">option3</option>

  </select>
      </td>

      <td name="td32" id="td32" class="td32"></td>

      <td name="td33" id="td33" class="td33"></td>

    </tr>

  </table>

</form>

<h1>你好世界!</h1>

</body>

</html>

JS代码

1.DOM对象与JQuery包装集

1.通过document.getElementById(),document.getElementsByName()等取的就是DOM对象或DOM对象集,前者取的是对象,后者取得DOM对象集

var text11_dom=document.getElementById("text11");

var text11_dom=document.getElementsByName("text11")[0];

var text11_dom=document.all.text11;//此处text11即可以是name值也可以是id值

var text11_dom=document.all[10];

2.如果要使用JQuery提供的函数首先要构造JQuery包装集,通过$()返回的即是JQuery包装集。
var text11_jquery=$("#text11");

2.JQuery包装集与DOM对象互相转换

1.DOM对象不能使用JQuery属性方法,但DOM对象可以通过$()转换成JQuery包装集

var text11_dom=document.getElementById("text11");

var text11_jquery=$(text11_dom);

2.JQuery包装集可以使用部分DOM对象的属性方法如.length,但也有个别属性方法不能使用如.value,可以通过在JQuery包装集后面加中括号及索引值获取对应DOM对象
var text11_dom=$("#text11")[0];

3.在each循环时或触发事件时的this也是DOM对象
$("#text11").click(function(){

    var text11_dom_value=this.value;

    alert(text11_dom_value);

});

3.$符号在JQuery中代表对JQuery对象的引用,JQuery的核心方法有四个

1.jQuery(html[,ownerDocument]):根据HTML原始字符串动态创建Dom元素

$("<div><p>Hello!</p></div>").appendTo("body");

2.jQuery( elements ):将一个或多个Dom对象封装为jQuery包装集,就是上面的DOM对象与JQuery包装集转换

3.jQuery( callback ):$(document).ready()的简写方式

$(function(){

    alert("Hello!");

});

 4.JQuery(selector[,context]):在指定范围内查找符合条件的JQuery包装集,context为查找范围,context可以是DOM对象集也可以是JQuery包装集
在所有tr标签中查找id为text11元素的JQuery包装集
var text11_query=$("#text11","tr");

===================jQuery选择器===================

1. 基础选择器 Basics

1.根据标签名进行选择

var input_query=$("input");

2.根据id值选取
var text11_query=$("#text11");

 3.根据class值进行选取
 
var text11_query=$(".text11");

 4.同时选择多个符合条件的JQuery包装集用,号分隔条件
 
var text_query=$("#text11,.text12");

 5.选择所有DOM元素
 
var all_query=$("*");

2.层次选择器 Hierarchy

1.从所有tr标签中获取其下面的所有id值为text11的元素

var text11_query=$("tr #text11");

 2.获取所有td标签下的所有直接input子元素
 
var input_query=$("td>input");

 3.获取id为text11元素后面的class为button11元素,只获取一个符合条件的元素。text11与button11在地位上属于同级关系
 
var button11_query=$("#text11+.button11");

 4.获取id为text11元素后面的所有class为button11的元素
 
var button11_query=$("#text11~.button11");

3.基本过滤器 Basic Filters

1.获取第一个input元素

var input_query=$("input:first");

 2.获取最后一个input元素
 
var input_query=$("input:last");

 3.获取所有未被选中的input元素
 
var input_query=$("input:not(:checked)");

 4.第一个input元素算一,查找所有第奇数个的input元素
 
var input_query=$("input:even");

 5.从第二个input算起,查找所有第偶数个的input元素
 
var input_query=$("input:odd");

 6.查找索引为1的input元素,索引值从0算起
 
var input_query=$("input:eq(1)");

 7.查找索引大于0的所有input元素
 
var input_query=$("input:gt(0)");

 8.查找索引小于2的所有input元素
 
var input_query=$("input:lt(2)");

 9.获取页面所有<h>标题元素
 
var h_query=$(":header");

 10.获取所有正在执行动画效果的元素
 
var animated_query=$(":animated");

4. 内容过滤器 Content Filters

1.查找所有html内容含有"你好世界!"的h1元素

var h1_query=$("h1:contains('你好世界!')");

 2.获取所有不含子标签或html内容为空的td元素
 
var td_query=$("td:empty");

 3.查找所有含有input子元素的td元素
 
var td_query=$("td:has(input)");

 4.查找所有含有子标签或有html内容的td元素
 
var td_query=$("td:parent");

5.可见性过滤器  Visibility Filters

1.查找所有隐藏的input元素

var input_query=$("input:hidden");

 2.查找所有可见的input元素
 
var input_query=$("input:visible");

6.属性过滤器 Attribute Filters
1.查找所有含有id属性的input元素
var input_query=$("input[id]");

 2.查找name值为text11的input元素
 
var input_query=$("input[name='text11']");

 3.查找name值不等于text11的所有input元素
 
var input_query=$("input[name!='text11']");

 4.查找name值以text开头的input元素
 
var input_query=$("input[name^='text']");

 5.查找name值以11结尾的所有input元素
 
var input_query=$("input[name$='11']");

 6.查找name值中含有ext的所有input元素
 
var input_query=$("input[name*='ext']");

 7.查找所有含有id属性并且name值中含有ext的input元素
 
var input_query=$("input[id][name*='ext']");

7.子元素过滤器 Child Filters

1.查找所有在父元素中的所有子元素中排第2的input元素
nth-child()里参数可选even在这里算偶数,odd在这里算奇数,n任意数即选取所有有父元素的input元素,数字是直接选排在第几个的input元素,第一个input元素算一

var input_query=$("input:nth-child(2)");

2.查找所有在父元素中的所有子元素中排第一的input元素
var input_query=$("input:first-child");

 3.查找所有在父元素中所有子元素中排最后一个的input元素
 
var input_query=$("input:last-child");

 4.查找所有在父元素中是唯一子元素的input元素
 
var input_query=$("input:only-child");

8.表单选择器 Forms

1.查找所有input元素

var input_query=$(":input");

 2.查找所有文本框元素
 
var text_query=$(":text");

 3.查找所有密码框元素
 
var password_query=$(":password");

 4.查找所有复选框
 
var checkbox_query=$(":checkbox");

 5.查找所有提交按钮元素
 
var submit_query=$(":submit");

 6.查找所有图像域元素
 
var image_query=$(":image");

 7.查找所有重置按钮元素
 
var reset_query=$(":reset");

 8.查找所有按钮元素
 
var button_query=$(":button");

 9.查找所有文件域元素
 
var file_query=$(":file");

9.表单过滤器 Form Filters

1.查找所有可用的input元素

var input_query=$("input:enabled");

 2.查找所有不可用的input元素
 
var input_query=$("input:disabled");

 3.查找所有选中的单选复选框
 
var input_query=$("input:checked");

 4.查找所有选中的下拉框
 
var option_query=$("option:selected");
Javascript 相关文章推荐
ASP.NET中基于JQUERY的高性能的TreeView补充
Feb 23 Javascript
javascript算法题:求任意一个1-9位不重复的N位数在该组合中的大小排列序号
Apr 01 Javascript
Bootstrap每天必学之表格
Nov 23 Javascript
jquery实现无刷新验证码的简单实例
May 19 Javascript
微信小程序 教程之WXSS
Oct 18 Javascript
js print打印网页指定区域内容的简单实例
Nov 01 Javascript
JS表单传值和URL编码转换
Mar 03 Javascript
解决vue动态为数据添加新属性遇到的问题
Sep 18 Javascript
利用d3.js实现蜂巢图表带动画效果
Sep 03 Javascript
vue3实现v-model原理详解
Oct 09 Javascript
原生js实现贪吃蛇游戏
Oct 26 Javascript
详细介绍Next.js脚手架完整搭建封装
Apr 26 Javascript
javascript字符串与数组转换汇总
May 26 #Javascript
javascript获取文档坐标和视口坐标
May 26 #Javascript
浅谈javascript事件取消和阻止冒泡
May 26 #Javascript
javascript事件冒泡和事件捕获详解
May 26 #Javascript
解析javascript中鼠标滚轮事件
May 26 #Javascript
JS中字符串trim()使用示例
May 26 #Javascript
JSON字符串和对象之间的转换详解
May 26 #Javascript
You might like
用PHP实现 上一篇、下一篇的代码
2012/09/29 PHP
PHP中Session引起的脚本阻塞问题解决办法
2014/04/08 PHP
php循环table实现一行两列显示的方法
2015/06/04 PHP
PHP缓冲区用法总结
2016/02/14 PHP
PHP用正则匹配form表单中所有元素的类型和属性值实例代码
2017/02/28 PHP
php实现的统计字数函数定义与使用示例
2017/07/26 PHP
laravel框架路由分组,中间件,命名空间,子域名,路由前缀实例分析
2020/02/18 PHP
用正则表达式 动态创建/增加css style script 兼容IE firefox
2009/03/10 Javascript
页面中iframe相互传值传参
2009/12/13 Javascript
js判断浏览器类型的方法
2013/08/07 Javascript
Iframe实现跨浏览器自适应高度解决方法
2014/09/02 Javascript
浅谈jQuery异步对象(XMLHttpRequest)
2014/11/17 Javascript
JS清除文本框内容离开在恢复及鼠标离开文本框时触发js的方法
2016/01/12 Javascript
jQuery 翻页组件yunm.pager.js实现div局部刷新的思路
2016/08/11 Javascript
详解React Native网络请求fetch简单封装
2017/08/10 Javascript
ECMAscript 变量作用域总结概括
2017/08/18 Javascript
JavaScript基础之流程控制语句的用法
2017/08/31 Javascript
Vue表单及表单绑定方法
2018/09/04 Javascript
封装微信小程序http拦截器过程解析
2019/08/13 Javascript
JavaScript实现捕获鼠标坐标
2020/04/12 Javascript
[47:42]Fnatic vs Liquid 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
wxPython中listbox用法实例详解
2015/06/01 Python
Python简单计算给定某一年的某一天是星期几示例
2018/06/27 Python
win10 64bit下python NLTK安装教程
2018/09/19 Python
Python基于百度云文字识别API
2018/12/13 Python
python对矩阵进行转置的2种处理方法
2019/07/17 Python
Python类中self参数用法详解
2020/02/13 Python
CSS Grid布局教程之什么是网格布局
2014/12/30 HTML / CSS
大学三年的自我评价
2013/12/25 职场文书
2014审计局领导班子民主生活会对照检查材料思想汇报
2014/09/20 职场文书
信用卡工资证明范本
2014/10/17 职场文书
2014年高二班主任工作总结
2014/12/16 职场文书
民间借贷被告代理词
2015/05/23 职场文书
《爬天都峰》教学反思
2016/02/23 职场文书
企业转让协议书(范文2篇)
2019/08/15 职场文书
mongodb的安装和开机自启动详细讲解
2021/08/02 MongoDB