首页 > web前端 > js教程 > 正文

jQuery三种$()使用案例

php中世界最好的语言
发布: 2018-04-23 10:56:29
原创
1249 人浏览过

这次给大家带来jQuery三种$()使用案例,jQuery三种$()使用的注意事项有哪些,下面就是实战案例,一起来看一下。

$号是jQuery“类”的一个别称,$()构造了一个jQuery对象。所以,“$()”可以叫做jQuery的构造函数(个人观点,呵呵!)。

1、$()可以是$(expresion),即css选择器、Xpath或html元素,也就是通过上述表达式来匹配目标元素。
比如:$("a")构造的这个对象,是用CSS选择器构建了一个jQuery对象——它选择了所有的这个标签。如:
$("a").click(function(){...})
就是在点击页面上的任何一个链接时的触发事件。确切地说,就是jQuery用
这个标签构建了一个对象$("a"),函数 click()是这个jQuery对象的一个(事件)方法。
比如有这样一段HTML代码:

而操作这段HTML的是如下一条语句:

$()中的是一个查询表达式,也就是用“p>p”这样一个查询表达式构建了一个jQuery对象,然后的“html()”意思是显示其html内容,也就是上面HTML代码段的[two]。再如:

$()中的是一个字符串,用这样一段字串构建了jQuery对象,然后向中添加这一字串。
2、$()可以是$(element),即一个特定的DOM元素。如常用的DOM对象有document、location、form等。如这样一行代码:

3、$()可以是$(function),即一个函数,它是$(document).ready()的一个速记方式。如常见的形式是这样的:

可变形作:

对于选择HTML文档中的elements,jQuery有两种方法:
1)如$("p>ul a"),它的意思是p标签中的ul标签中的a标签
不过,$('p>ul')和$('p ul')是有区别的,

2)用jQuery对象的几个方法(如方法find()、each()等)
$("#orderedlist).find("li") 就像 $("#orderedlist li"). each()一样迭代了所有的li,而表达式中的“#”表示HTML中的ID,如上例中的“#orderedlist”就表示“ID为orderedlist所在的标签”。
****************************************************************
1、
标签选择器$('p')、类选择器$('.myClass')、id选择器$('#myId')相对简单,不多说。不过有一点——$('p>ul')和$('p ul')是有区别的,
$('p>ul')是

的直接后代里找

    ;而$('p ul')是在

    的所有后代里找


      所以,$('#sId>li')所选择的是id为"sId"的所有
    • 孩子节点,即使这个
    • 的后代还有
    • 也不是它所找的范围(所找到的DOM对象,只是它本级的DOM对象。)。而$('#sId li:not(.horizontal)'),就是指类名"sId"里面的所有li的子孙中没有horizontal类的所有元素。——这里的not()是一个negation pseudo class.
      这里返回的是一个jQurey对象,一个数组对象,这个jQuery对象的长度可用.length()得到。
      2、XPath选择器
      如:选择所有带有title 属性的链接,我们会这样写:$('a[@title]')
      []里带@,说明[]里的是元素的属性;是个属性选择器
      []里没@,说明[]里的是元素的子孙。
      $('ul li')和$('ul[li]')虽然返回的都是一个jQuery数组,但两者的含义正好相反。前者是要找
        下所有
      • 子孙,而后者却是在找所有子孙为
        • 数组。
          在XPath中,要找一个“以...开头”的属性,用^=,如找一个name属性是以mail开头的input元素,就用
          $('input[@name^="mail"]')
          要找一个“以...结尾”的属性,要用$=
          要找一个“不头不尾”的属性,用*=
          3、不属于上述的CSS和XPath的选择器,就是自定义的选择器了,用“:”表示,这里要用的就是:

          first,:last,:parent ,:hidden,:visible,:odd,:even,:not('xxx'), ":eq(0)"(始于0),:nth(n),:gt(0),:lt(0),:contains("xxx")
          登录后复制

          如:$('tr:not([th]):even')意为元素的子孙中不含的所有子孙的偶数项
          4、还有几个,简单不解释了

          $('th').parent()—— 
          $(&#39;td:contains("Henry")&#39;).prev()——内容包含有"Henry"的<td>的上一个节点 
          $(&#39;td:contains("Henry")&#39;).next()——内容包含有"Henry"的<td>的下一个节点 
          $(&#39;td:contains("Henry")&#39;).siblings()——内容包含有"Henry"的<td>的所有兄弟节点
          登录后复制

          还有一个,就是end(),这个方法肯定是用在某个DOM节点执行了某一动作之后,还想在与其相关的节点上执行类似动作,这里就要用到end()。用过end()方法之后,所返回的是执行动作的那个节点的父节点上。举个例子

          $(...).parent().find(...).addClass().end()
          登录后复制

          这里执行动作的节点是find(...),是一个数组对象,它所做的动作是“addClass()”,之后,用了个end(),这时所返回的东东就是指向了parent()所指向的节点,也就是执行“addClass()”动作的那个数组对象的父节点。
          5、要直接访问DOM元素,可用get(0)的方法,如

          $(&#39;#myelement&#39;).get(0),也可缩写成$(&#39;#myelement&#39;)[0]
          登录后复制

          相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

          推荐阅读:

          js仿jquery步骤详解

          JS中时间单位比较的方法

          以上是jQuery三种$()使用案例的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板