▓▓▓▓▓▓ 大致介绍

  终于开始了我的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的背景色

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

▓▓▓▓▓▓ 层次选择器

  选取div里的所有span元素

         $('div span');

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

         $('div > span');

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

        $('.one + div');

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

        $('.one ~ div');

▓▓▓▓▓▓ 过滤选择器

  1、基本过滤选择器

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

         $('div:first');

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

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

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

        $('div:even');

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

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

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

         $('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学习之路(1)-选择器的更多相关文章

  1. jquery学习笔记(一):选择器

    内容来自[汇智网]jquery学习课程 1.1 基础选择器 选择器 功能 返回值 #id 根据给定的id匹配一个元素 单个元素 element 根据给定的元素名匹配所有元素 元素集合 .class 根 ...

  2. jQuery 学习之路(2):选择器与过滤器

    一.基本选择器 标签选择器: $('button') ID选择器: $('#id1') 类选择器: $('.class1') 多重选择器: $('#id1,.class1,button') 全体选择器 ...

  3. jQuery学习之路(7)- 用原生JavaScript实现jQuery的某些简单功能

    ▓▓▓▓▓▓ 大致介绍 学习了妙味,用原生的JavaScript实现jQuery中的某些部分功能 定义自己的函数库lQuery ▓▓▓▓▓▓ $()选择器的实现 jQuery是面向对象的,所以自己编写 ...

  4. jQuery 学习之路(1):引子

    一.主流 javascript 库 除 jQuery 外,还有 Prototype.Dojo.YUI.ExtJS.MooTools ,其中 Prototype 较老,结构设计较为松散,ExtJS 界面 ...

  5. jquery学习(2)--选择器

    jquery-李炎恢学习视频学习笔记.自己手写. 简单的选择器    css 写 法: #box{ color:#f00;}    //id选择器    jquery获取:$('#box').css( ...

  6. jQuery学习之旅 Item1 选择器【一】

    点击"名称"会跳转到此方法的jQuery官方说明文档. 1. 基础选择器 Basics 名称 说明 举例 #id 根据元素Id选择 $("divId") 选择I ...

  7. jQuery学习之路(8)- 表单验证插件-Validation

    ▓▓▓▓▓▓ 大致介绍 jQuery Validate 插件为表单提供了强大的验证功能,让客户端表单验证变得更简单,同时提供了大量的定制选项,满足应用程序各种需求.该插件捆绑了一套有用的验证方法,包括 ...

  8. jQuery学习之路(2)-DOM操作

    ▓▓▓▓▓▓ 大致介绍 jQuery作为JavaScript库,继承并发扬了JavaScript对DOM对象操作的特性,使开发人员能方便的操作DOM对象. ▓▓▓▓▓▓ jQuery中的DOM操作 看 ...

  9. jQuery学习之旅 Item2 选择器【二】

    这里接着上一个Item1 把jQuery的选择器讲完.主要有:属性过滤器和子元素过滤器 点击"名称"会跳转到此方法的jQuery官方说明文档. 5. 属性过滤器 Attribute ...

随机推荐

  1. Linux下服务器端开发流程及相关工具介绍(C++)

    去年刚毕业来公司后,做为新人,发现很多东西都没有文档,各种工具和地址都是口口相传的,而且很多时候都是不知道有哪些工具可以使用,所以当时就想把自己接触到的这些东西记录下来,为后来者提供参考,相当于一个路 ...

  2. SDWebImage源码解读之SDWebImageCache(上)

    第五篇 前言 本篇主要讲解图片缓存类的知识,虽然只涉及了图片方面的缓存的设计,但思想同样适用于别的方面的设计.在架构上来说,缓存算是存储设计的一部分.我们把各种不同的存储内容按照功能进行切割后,图片缓 ...

  3. 动手做第一个Chrome插件

    Chrome插件是令人惊讶的简单,一旦你弄懂它的工作和实现原理.它是由一部分HTML,一部分Js,然后混合了一个叫做manifest.json的Json文件组合而成的整体.这意味着你可以使用你最擅长的 ...

  4. CSS 3学习——transition 过渡

    以下内容根据官方规范翻译以及自己的理解整理. 1.介绍 这篇文档介绍能够实现隐式过渡的CSS新特性.文档中介绍的CSS新特性描述了CSS属性的值如何在给定的时间内平滑地从一个值变为另一个值. 2.过渡 ...

  5. jquery.cookie的使用

    今天想到了要为自己的影像日记增加赞的功能,并且需要用到cookie. 记得原生的js操作cookie也不是很麻烦的,但似乎jquery更简单,不过相比原生js,需要额外引入2个文件,似乎又不是很好,但 ...

  6. js面向对象学习 - 对象概念及创建对象

    原文地址:js面向对象学习笔记 一.对象概念 对象是什么?对象是“无序属性的集合,其属性可以包括基本值,对象或者函数”.也就是一组名值对的无序集合. 对象的特性(不可直接访问),也就是属性包含两种,数 ...

  7. bzoj3095--数学题

    题目大意:给定一个长度为n的整数序列x[i],确定一个二元组(b, k)使得S=Σ(k*i+b- x[i])^2(i∈[0,n-1])最小 看Claris大神的题解就行了.实际上就是用2次二次函数的性 ...

  8. webix前端架构的项目应用

    webix框架兼容javascript.HTML.CSS,应用比较灵活,应用框架时,配合后台webAPI,整个web项目里面,App文件夹保存前台的多语言文件,图片文件,webix原代码js.css, ...

  9. css_02之盒模型、渐变

    1.框模型:盒模型,①对象实际宽度=左右外边距+左右边框+左右内边距 + width:②对象实际高度=上下外边距+上下边框+上下内边距 + height: 2.外边距:margin:取值:①top(上 ...

  10. 项目持续集成环境(jenkins + SVN + maven + tomcat)

    整体流程 每次SVN上代码有变动,触发自动构建动作,并部署到服务器的tomcat上,具体流程: 1.SVN上提交代码修改 2.maven执行Goals 3.将web工程打成war包 4.关闭服务器的t ...