jQuery学习之路-选择器

Posted 老板丶鱼丸粗面

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了jQuery学习之路-选择器相关的知识,希望对你有一定的参考价值。

▓▓▓▓▓▓ 大致介绍

  终于开始了我的jQuery学习之路!感觉不能再拖了,要边学习原生javascript边学习jQuery

  jQuery是什么?

  jQuery是一个快速、简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架)。jQuery设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化html文档操作、事件处理、动画设 计和Ajax交互。
  jQuery的核心特性可以总结为:具有独特的链式语法和短小清晰的多功能接口;具有高效灵活的css选择器,并且可对CSS选择器进行扩展;拥有便捷的插件扩展机制和丰富的插件。jQuery兼容各种主流浏览器,如IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+等。(来自百度-_-)
 

▓▓▓▓▓▓ jQuery对象和DOM对象

  我们在编写脚本时,可能会同时用到原生JavaScript和jQuery,那么这时就会存在一些问题。要解决这些问题就先得认识jQuery对象和DOM对象

    DOM对象:通过例如getElementById方法获取到DOM树中的元素就是DOM对象

    jQuery对象:通过jQuery包装DOM对象后产生的对象

  注意:jQuery对象和DOM对象不能使用对方的任何方法

        // 错误
        $(\'div\').innerHTML;

        // 错误
        document.getELementsByTagName(\'div\')[0].html();

  

  jQuery对象和DOM对象是可以互相转化的

  jQuery对象转成DOM对象有两种方法:

    1、[index]

        var $div = $(\'div\');//jQuery对象
        var div = $div[0];//DOM对象

 

    2、get(index)

        var $div = $(\'div\');//jQuery对象
        var div = $div.get(0);//DOM对象

  

  DOM对象转成jQuery对象有一种方法:$(DOM对象)

        var div = document.getELementsByTagName(\'div\')[0];//DOM对象
        var $div = $(div);//jQuery对象

 

▓▓▓▓▓▓ jQuery选择器

  jQuery中的选择器完全继承了CSS的风格

  逐一来看

▓▓▓▓▓▓ 基本选择器

  改变id为div1的所有div的背景色

        $(\'#div1\').css(\'background\',\'#bbffaa\');

  

  改变所有p标签和class为one的div的背景色

1         $(\'p,.one\').css(\'background\',\'#bbffaa\');

 

▓▓▓▓▓▓ 层次选择器

  选取div里的所有span元素

1         $(\'div span\');

  选取div下元素名是span的子元素

1         $(\'div > span\');

  选取class是one的下一个<div>同辈元素

        $(\'.one + div\');

  选取class是one的后面的所有的<div>同辈元素

        $(\'.one ~ div\');

 

▓▓▓▓▓▓ 过滤选择器

  1、基本过滤选择器

    选取所有<div>元素中第一个<div>元素

1         $(\'div:first\');

    选取class不是one的<div>元素

        $(\'div:not(.one)\');

    选取索引是偶数的的<div>元素

        $(\'div:even\');

    选取索引等于2的<div>元素

        $(\'div:eq(2)\');

    选取索引大于2的<div>元素

1         $(\'div:gt(2)\');

    选取所有标题元素,例如h1、h2等

        $(\':header\');

    选取当前正在执行动画的所有元素

        $(\':animated\');

    选取获取当前焦点的元素

        $(\':focus\');

 

  2、内容过滤选择器

    选取含有文本“坚持”的<div>元素

        $(\'div:contains(\'坚持\')\');

    选取不包含子元素或者文本的<div>元素

        $(\'div:empty\');

    选取含有<p>元素的<div>元素

        $(\'div:has(p)\');

    选取含有子元素或者文本的元素

        $(\'div:parent\');

 

  3、可见性过滤选择器

    选取所有不可见的元素。包括<input type="hidden" />,<div style="display:none">和<div style="overflow:hidden">

        $(\':hidden\');

    选取所有可见的<div>元素

        $(\'div:visible\');

 

  4、属性过滤选择器

    选取有id属性的元素

        $(\'div[id]\');

    选取id等于myId的<div>元素

        $(\'div[id="myId"]\');

    选取id值不等于myId的<div>元素

        $(\'div[id!="myId"]\');

    选取id值以my开头的<div>元素

        $(\'div[id^="my"]\');

    选取id值以my结尾的<div>元素

        $(\'div[id$="my"]\');

    选取id值含有my的<div>元素

        $(\'div[id*="my"]\');

    选取属性title等于en或者以en为前缀(en后跟一个连字符\'-\')的元素

        $(\'div[title|="en"]\');

    选取属性title中用空格分隔的值中包含字符en的<div>元素

        $(\'div[title~="en"]\');

    选取拥有属性id并且属性title以en为前缀的<p>元素

        $(\'p[id][title|="en"]\');

 

  5、子元素过滤器

    选取每个class为one的<div>父元素下的第2个子元素

        $(\'div.one :nth-child(2)\');

    选取每个class为one的<div>父元素下的第1个子元素

        $(\'div.one :first-child\');

    选取<ul>中是唯一子元素的<li>元素

        $(\'ul li:only-child\');

 

  6、表单对象属性过滤选择器

    选取id为"form1"表单内的所有可用元素

        $(\'#form1:enabled\');

    选取id为"form1"表单内的所有不可用元素

        $(\'#form1:disabled\');

    选取所有被选中的<input>元素

        $(\'input:checked\');

    选取所有被选中的选项元素

        $(\'select option:selector\');

 

▓▓▓▓▓▓ 表单选择器

    选取所有的<input>、<textarea>、<select>和<button>元素

        $(\':input\');

    选取所有的单行文本框

        $(\':text\');

    选取所有的不可见的元素

        $(\':hidden\');

    其余的选择方法都可以通过单词了解到意思(例如 :submit 就是选择所有的提交按钮)就不再赘述。

    

  参考资料:锋利的jQuery(第二版)

       http://www.jquery123.com/

  

以上是关于jQuery学习之路-选择器的主要内容,如果未能解决你的问题,请参考以下文章

jQ选择器学习片段(JavaScript 部分对应)

jquery学习之路之测验错题集

JQuery02

jquery中的$的特殊用法

jQuery学习手册

jQuery学习之路-DOM操作