zoukankan      html  css  js  c++  java
  • jQuery学习笔记(2)-选择器的使用

    一、选择器是什么

    有了jQuery的选择器,我们几乎可以获取页面上任意一个或一组对象

    二、Dom对象和jQuery包装集

    1.Dom对象

    JavaScript中获取Dom对象的方式

    <div id="divMsg">Hello World</div>
    <script>
        var div = document.getElementById("divMsg");
        console.log(div);
        var divs = document.getElementsByTagName("div");
        console.log(divs);
    </script>

    输出的结果

    image

    2.jQuery包装集

    可以理解为是Dom对象的扩展,在jQuery的世界中所有的对象,都被封装成一个jQuery包装集,包装集是一个集合

    <div id="divMsg">Hello World</div>
    <script>
        $(function () {
            var div = $("#divMsg");
            console.log(div);
            var divs = $("div");
            console.log(divs);
        })
    </script>

    输出的结果

    image

    3.Dom对象与jQuery对象的转换

    (1)Dom转jQuery包装集

    <div id="divMsg">Hello World</div>
    <script>
        //第一步:获取Dom元素对象
        var div = document.getElementById("divMsg");
        //第二步:使用$()来转换
        var $div = $(div);
        console.log($div);
    </script>

    (2)jQuery包装集转Dom对象

    注:通过索引器返回的不再是jQuery包装集,而是一个Dom对象

    <div id="divMsg">Hello World</div>
    <script>
        //第一步:通过索引器从包装集获取一个元素
        var div = $("#divMsg")[0];
        console.log(div);
    </script>

    三、选择器的分类

    1.jQuery选择器按照功能主要分为“选择”和“过滤”。并且可以配合使用,可以同时使用组合成一个选择器字符串。主要的区别是:“过滤”作用的选择器是指定条件从前面匹配的内容中筛选,“过滤”选择器也可以单独使用,表示从全部“*”中帅选。比如

    $(":[title]") 等同于 $("*:[title]")

    而“选择”功能的选择器则不会有默认的范围,因为作用是“选择”而不是“过滤”;

    2.基础选择器Basics

      1 $("#divId") 		         选取ID为divId的元素
      2 $("a") 			选取所有<a>元素
      3 $(".bgRed") 			选取class为bgRed的元素
      4 $("*")			选取所有元素
      5 $("#divId, a.bgRed")		选取ID为divId的元素,和class为.bgRed的<a>元素

    3.层次选择器

      1 $(".bgRed div") 		选取class为bgRed的元素中的所有<div>元素
      2 $(".myList>li") 		选取class为myList元素中的直接子节点<li>对象
      3 $("#hibiscus+img")		选取在id为hibiscus元素后面的img对象
      4 $("#someDiv~[title]")		选取id为someDiv的对象后面所有带有title属性的元素

    4.基本过滤器Basic Filters

      1 $("tr:first")		         选取第一个<tr>元素
      2 $("tr:last")			选取最后一个<tr>元素
      3 $("input:not(:checked)")         选取未选中的 <input> 元素
      4 $("tr:odd")			选取偶数位置的<tr>元素
      5 $("tr:eq(1)")			选取第2个<tr>元素(索引从0开始)
      6 $("tr:gt(0)")			选取索引大于等于1的<tr>元素
      7 $("tr:lt(2)")			选取索引小于2的<tr>元素
      8 $(":header")                     选取页面所有的标题

    5.内容过滤器Content Filters

      1 $("div:contains('Kimisme')")     选取包含 "Kimisme" 的 <div>元素
      2 $("td:empty")			选取不包含子元素或者文本的<td>元素
      3 $("div:has(p)")		选取含有<p>元素的<div>元素
      4 $("td:parent")			选取含有子元素或者文本的 <td> 元素

    6.可见性过滤器 Visibility Filters

      1 $("tr:hidden")			选取不可见的 <tr> 元素:
      2 $("tr:visible")		选取可见的 <tr> 元素:

    7.属性过滤器 Attribute Filters

      1 $("div[id]")			选取含有 id 属性的 <div> 元素
      2 $("input[name='newsletter']")	选取 name 属性是 newsletter 的 <input> 元素
      3 $("input[name!='newsletter']")	选取 name 属性不是 newsletter 的 <input> 元素
      4 $("input[name^='news']")	选取 name 属性以news开头的 <input> 元素
      5 $("input[name$='letter']")	选取 name 以 letter 结尾的 <input> 元素: 
      6 $("input[name*='man']")		选取 name 包含 man 的 <input> 元素
      7 $("input[id][name$='man']")	选取含有 id 属性,并且它的 name 属性是以 man 结尾的<input>元素

    8.子元素过滤器 Child Filters

      1 $("ul li:nth-child(2)")		在 <ul> 元素中查找第2个 <li> 元素
      2 $("ul li:first-child")		在 <ul> 元素中查找第1个 <li> 元素 
      3 $("ul li:last-child")		在 <ul> 元素中查找最后一个 <li> 元素 
      4 $("ul li:only-child")		在 <ul> 元素中查找是唯一子元素的 <li> 元素

    9.表单选择器Forms

      1 $(":input")			选取所有的<input>元素
      2 $(":text")			选取所有type=”text”的文本框
      3 $(":password")		         选取所有密码框
      4 $(":radio")			选取所有单选按钮
      5 $(":checkbox")		         选取所有复选框 
      6 $(":submit")		         选取所有提交按钮
      7 $(":image")			选取所有图像域
      8 $(":reset")			选取所有重置按钮
      9 $(":button")		         选取所有按钮
     10 $(":file")			选取所有文件域

    10.表单过滤器Form Filters

      1 $("input:enabled")		选取所有可用的input元素: 
      2 $("input:disabled")		选取所有不可用的input元素: 
      3 $("input:checked")		选取所有选中的复选框元素:
      4 $("select option:selected")	选取所有选中的<select>元素:

    四、参考文章

    http://www.cnblogs.com/zhangziqiu/archive/2009/05/03/jQuery-Learn-2.html

    五、备注

    样式发不出来还是不行,还是要用table,有空再改

    更多精彩内容请看:http://www.cnblogs.com/2star
  • 相关阅读:
    springboot事务注解@Transactional
    Springboot + mybatis + React+redux+React-router+antd+Typescript(三): 上线
    Springboot + mybatis + React+redux+React-router+antd+Typescript(二): React+Typescrip项目的搭建
    Springboot + mybatis + React+redux+React-router+antd+Typescript(一): 后台Springboot+Mybatis的搭建
    spring(四):spring与mybatis结合
    spring(三):springAOP的各种织入方式一览
    spring(二):简单阐述springAOP的实现原理
    spring(一):spring IoC的注入方式总结
    java web(七): mybatis的动态sql和mybatis generator自动生成pojo类和映射文件
    java web(六):mybatis之一对一、一对多、多对多映射
  • 原文地址:https://www.cnblogs.com/kimisme/p/5289402.html
Copyright © 2011-2022 走看看