学习jquery-Jquery基础知识

(原文地址http://www.cnblogs.com/ILYljhl/p/3180253.html)  

 一、jquery是什么?

        其实它就是我看不懂的js的一个框架,其主要思想是,通过选择器(jquery选择器非常强大)查找对应的节点,然后对这个节点做一个封装(封装成jquery对象)。通过调用jquery对象的属性和方法来实现对节点的操作。

        使用jquery的好处是:

        1、将不同浏览器之间的差异兼容起来;(这个我的理解非常浅,谁懂的说下咯)

        2、代码更加简洁,维护方便。这个我知道。

      二、使用jquery编程的步骤?

        1、先把要操作的节点找到,怎么找呢?用jquery的选择器去找(非常强大的选择器);

        2、找到节点后,因为此时找到的节点都被封装成jquery对象了,所以就调用该对象的属性和方法来实现对节点的操作;

      鉴于我目前对于对象的属性和方法还不太了解,我就先学好强大的jquery选择器吧!

      三、什么是选择器?

        懂的css的人都知道它有自己的选择器,其实jquery选择器就是模仿到css选择器来的,所以我觉得上手快些!jquery选择器支持css1和css2的全部和css3的部分选择器,同时它也有少量的独有的选择器。选择器分为4类:基本选择器、层次选择器、过滤选择器(基本过滤选择器、内容过滤选择器、可见性过滤选择器、属性过滤选择器、子元素过滤选择器、表单对象属性过滤选择器)、表单选择器。

        下面一一说明:

        1、基本选择器:最常用也是最简单的选择器。它通过id、class、标签名等来查找节点元素。每个id只允许出现一次,而class允许重复使用。

#id 给指定的id匹配一个元素 返回单个元素 $("#test") id为test的元素
#class 匹配给定的类名 返回集合元素 $(".test")类名为test的元素
element 匹配给定的标签名 返回集合元素 $("p")所有的p元素
* 匹配所有元素 返回集合元素 $("*")html中的所有元素(少用)
selector1、selctor2。。。selectorN 匹配给定的集合 返回集合元素 $("div,span,p.myclass")所有的div,span和类名为myclass的p元素

         2、层次选择器:通过节点元素之间的层次关系来获得特定元素、例如后代元素、子元素、相邻元素、兄弟元素。

$("ancestor descendant") 选取ancestor里所有的descendant元素 返回集合元素 $("div span")选取div里的所有span元素
$("parent>child") 选取parent下的child元素,与第一个不同哈 返回集合元素 $("div>span")选取div下的元素名是span的元素
$("prev+next") 选取紧接在prev后的next元素 集合元素 $(".one+div")选取class为one的下一个div元素
$("prev~siblings") 选取prev元素之后的所有siblings元素 集合元素 $(".one~div")选取class为one元素后面的所有div元素

            在层次选择器中,第一个和第二个比较常用,而第三个和第四个可以在jquery中用更加简单的方法代替,所以使用的几率小些。可以用next()代替$("prev+next"),用nextAll()方法代替$("prev~siblings");这里将siblings()方法与$("prev~siblings")进行比较:siblings()方法呢获取的是这个元素的兄弟元素包含前面或者后面的,与位置无关。而$("prev~siblings")只能获取这个元素后面的兄弟元素。

          3、过滤选择器就分类多了。主要是通过特定的过滤规则来筛选出所需的DOM元素,过滤规则与css中的伪类选择器语法相同,即选择器都以":"开头。

             3(1)、基本过滤选择器

:first 选取第一个元素 返回单个元素 $("div:first")获取所有div元素的第一个div元素
:last 选取最后一个元素 返回单个元素 $("div:last")获取所有div元素中的最后一个div元素
:not(selector) 去除所有匹配selector选择器的元素 返回集合元素 $("div:not(.mydiv)")选取class名不为mydiv的所有div元素
:even 选取索引为偶数的元素,注意:索引从0开始 返回集合元素 $("input:even")选取索引为偶数的input元素
:odd 选取索引为奇数的元素 返回集合元素 $("input:odd")选取索引为奇数的input元素
:eq(index) 选取索引为index的元素 返回单个元素 $("input:eq(1)")选取索引为1的input元素
:gt(index) 选取索引大于index的元素 返回集合元素 $("input:gt(4)")选取索引大于4的input元素
:lt(index) 选取索引小于index的元素 返回集合元素 $("input:lt(4)")选取索引小于4的input元素
:header 选取所有的标题元素,例如h1,h2,h3``h6 返回集合元素  $(":hear")选取网页中的所有标题元素
:animated 选取当前正在执行动画的元素(常用语判断语句中) 返回集合元素 $("div:animated")选取正在执行动画的div元素

             3(2)、内容过滤选择器

:contains(text) 选取含有文本内容为text的元素 返回集合元素 $("div:contains("我"))选取含有我文本的所有div元素
:empty 选取不包含子元素或者文本的空元素 集合元素 $("div:empty")选取不包含子元素或者文本元素的div元素,相当于空标签
:has(selector) 选取有所匹配元素的元素 返回集合元素 $("div:has(p)")选取含有p元素的div元素
:parent 选取含有子元素或者文本元素的元素 返回集合元素 $("div:parent")选取含有子元素和文本元素的div元素

              3(3)、可见性过滤选择器,根据元素的可见和不可见行来选择相应的元素

:hidden 选取所有不可见元素 返回集合元素

$(":hidden")选取所有不可见的元素,

包括<input type="hidden"><div style="display:none"><div style="visibility:hidden">等元素

:visible 选取所有可见元素 返回集合元素 $(div:visible")选取所有可见的div元素

             3(4)、属性过滤选择器,通过元素的属性来获取相应的元素。

[attribute] 选取拥有此属性的元素 集合元素 $("div[id]")选取拥有id属性的div元素
[attribute=value] 选取属性的值为value的元素 集合元素 $("div[title="mytitle"])选取title属性为mytitle的div元素

[attribute!=value]

选取属性的值不为value的元素

集合元素

$("div[title!="mytitle"])选择title属性不为mytitle的div元素

[attribute^=value]

选取属性的值以value开始

集合元素

$("div[title^="a"]")选取title属性以a字母开头的div元素

[attribute$=value]

选取属性的值以value结束

集合元素

$("div[title$="a"]")选取title属性以a字母结束的div元素

[attribute*=value]

选取属性的值含有value的元素

集合元素

$("div[title*="a"]")选取title属性含有a字母的div元素

[selector1][selector2]

[selectorN]  

用属性选择器合并成一个复合属性选择器,满足多个条件,

每选择一次就会缩小一次范围

集合元素 $("div[id][title="mytitle"]")选取含有i的属性且title属性为mytitle的div元素

             4(5)、子元素过滤选择器,子元素过滤选择器相对于其他选择器要稍微复杂些,注意它与普通的过滤器的差别。

:nth-child(index/odd/even/equation) 选取每个父元素下的第index个元素或者奇偶元素(index从1算起) 集合元素 :eq(index)只匹配一个元素,:nth-child(index)将为每一个父元素匹配子元素,并且他的index是从1开始算起的
:first-child 选取每个父元素下的第一个子元素 集合元素 :first只获取单个元素,而:first-child获取每个父元素下个的第一个子元素
:last-child 选取每个父元素下的最后一个元素 集合元素 同理
:only-child

如果某个元素时它父元素中的唯一一个子元素,那么将会被匹配,

如果父元素中含有其他元素,那么将不会被匹配

集合元素 $("ul li:only-child")在ul中选取是唯一子元素的li元素

             3(6)、表单对象属性过滤选择器,表单对象比如被选中的下拉框、多选框等。

:enabled 选取所有可用元素 集合元素 $("#form:enabled")选取id为form的表单里所有可用元素
:disabled 选取所有不可用元素 集合元素 选取不可用的元素
:checked 选取被选择的元素(单选框、复选框) 集合元素 $("input:checked")选取所有被选中的input元素
:selected 选取所有被选中的选项元素(下拉列表) 集合元素 $("selected:selected")选取所有被选中的选中元素

          4、表单对象选择器,利用这个选择器能极其方便的获取到表单的某个或某个类型的元素。

:input 选取所有的<input>,<textarea>,<select>,<button>元素 集合元素 $(":input")
:radio 选取所有的单选框元素 集合元素 $(":radio")
:file 选取所有的上传域 集合元素 $(":file")
:text 选取所有的单行文本框 集合元素 $(":text")
:password 选取所有密码框 集合元素 $(":password")
:checkbox 选取所有复选框 集合元素 $(":checkbox")
:submit 选取所有提交按钮 集合元素 $(":submit")
:image 选取所有图像按钮 集合元素 $(":image")
:reset 选取所有重置按钮 集合元素 $(":reset")
:button 选取所有的按钮 集合元素 $(":button")
:hidden 选取所有不可见的元素 集合元素 $(":hidden")

     合理的利用每个选择器,达到事半功倍的效果!没事来看看加深加深印象,对于那些大神们,你们就绕道而行吧!

评论 12
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值