Jquery:小知识;

Jquery:小知识;

jQuery学习笔记(二):this相关问题及选择器

上一节的遗留问题,关于this的相关问题,先来解决一下。

this的相关问题

this指代的是什么

这个应该是比较好理解的,this就是指代当前操作的DOM对象。

在jQuery中,this可以用于单个对象,也可以用于多个对象。

$(‘btn‘).click(function(){
    alert(this.innerHTML);  // 单个对象,this指代当前id为btn的DOM对象
});

$(‘div‘).each(function(index){
    alert(this.innerHTML);  // 多个对象,this指代当前循环中索引为index的DOM对象
});

jQuery中的this和$(this)有什么区别

jQuery中的this和$(this)有什么区别

$("div").each(function(index){
     alert($(this));  // [object Object] jQuery对象
     alert(this);    // [object HTMLDivElement] DOM对象
});

可以观察到,this指代的是DOM对象,$(this)指代的是包装当前DOM对象的jQuery对象。

jQuery选择器

上一节也分析到,jQuery的最大贡献之一就是方便的获取DOM元素,并对DOM元素进行操作。

先看几个简单的例子:

$(‘div‘);  // 选择所有标签为div的DOM元素

$(‘#info‘);  // 选择id为info的DOM元素

$(‘div>p‘);  // 选择所有div标签下的子集标签为p的DOM元素

$(‘input[placeholder*="info"]‘);  // 获取所有input标签中,属性placeholder值中包含info字段的DOM元素

$(‘p:odd‘);  // 获取所有标签为p的元素压入栈中,选择其中索引值为奇数的DOM元素

可以看到,有多种选择方式让你获取你所需要的对象,这些先作为一个引子,让我们对jQuery的选择器有一个大致上的印象。现在以开发者的角度来思考:如何选择需要的DOM元素。

1. 首先能想到的是,获取指定id的元素,对其进行操作。

$(‘#info‘);  // 获取id为info的元素

2. 既然可以获取指定id的元素,那么理所应当的,也可以获取指定class的元素。

$(‘.info‘);  // 获取class为info的元素

3. 有时会遇到一系列具有相同className的元素,而这些元素之间没有办法互相区分彼此。

<!DOCTYPE html>
<html>
    <head>
        <title>Test</title>
    </head>
    <body>
      <div class=‘info‘>0</div>
      <div class=‘info‘>1</div>
      <div class=‘info‘>2</div>
      <div class=‘info‘>3</div>
      <div class=‘info‘>4</div>
    </body>
</html>   

这时,如果我想获取这一系列元素中的第一个:

$(‘.info:first‘).val();  // 获取class为info的一系列元素中的第一个元素的值,即0

我想获取这一系列元素中的最后一个:

$(‘.info:last‘).val();  // 获取class为info的一系列元素中的最后一个元素的值,即4

那获取任意一个元素呢?

$(‘.info:eq(2)‘).val();  // 获取class为info的一系列元素中索引为2的元素的值,即2(索引从0开始)

看来选择单个元素还是很方便的,那要是选择符合某些条件的复数个元素呢?比如选择这一组元素的后三个元素:

$(‘.info:gt(1)‘);  // 获取class为info的一系列元素中索引大于1的对象,即2,3,4
$(‘.info:lt(2)‘);  // 获取class为info的一系列元素中索引小于2的对象,即0,1

选择系列元素中索引为奇数的元素(好像很少这么做,但jQuery也为我们提供了选择器)

$(‘.info:odd‘);  // 获取class为info的一系列元素中索引为奇数(1,3)的对象,即1,3 $(‘.info:even‘);  // 获取class为info的一系列元素中索引为偶数(0,2,4)的对象,即0、2、4

4. 比如现在有一系列链接元素,但是它们并没有唯一id标识,也没有className区分,各个元素之间仅有href是不一致的,该如何选择需要的元素呢?

<!DOCTYPE html>
<html>
    <head>
        <title>Test</title>
    </head>
    <body>
        <div>
          <a>0</a>
          <a href=‘/info‘>1</a>
          <a href=‘/infomation‘>2</a>
          <a href=‘/test‘>3</a>
        </div>
    </body>
</html>   

比如我想选择带有href属性的a标签元素:

$(‘a[href]‘);  // 选择带有href属性的a标签,即1,2,3

选择href属性值为info的a标签元素:

$(‘a[href="info"]‘);  // 选择href属性为info的a标签,即1

选择href属相值已info开头的a标签元素:

$(‘a[href^="info"]‘);  // 选择带有href属性值已info开头的a标签,即1,2

选择href属性值已tion结尾的a标签元素:

$(‘a[href$="tion"]‘);  // 选择带有href属性值已tion结尾的a标签,即2

选择href属性值中有fo字段的a标签元素:

$(‘a[href*="fo"]‘);  // 选择带有href属性值中包含fo的a标签,即1,2

当然,也可以进行反选,选择href属性值中不包含info的a标签元素:

$(‘a[href!="info"]‘);  // 选择带有href属性值中不包含info的a标签,即3

5. 还有会遇到一些情况,要求我们根据DOM元素的内容来选择合适的元素。

$(‘div:contains("info")‘); // 选择div标签中内容包含info字段的元素

6. 现在我们已经通过指定id、class或是指定索引值、属性值来确定元素,让我们换个角度,有没有可能从元素之间的关系来确定元素呢?

先统一名称:

同级元素:即当前元素处于同一层级。

<div>
    <p>0</p>  // 当前两个标签为p的元素处于同一层级,属于同级元素
    <p>1</p>
</div>

父级元素:即当前元素的直属上层元素。

祖先元素:即当前元素的所有上层元素。

子级元素:即当前元素的直属子层元素。

后代元素:即当前元素的所有子层元素。

<div id=‘ancestor‘>
    <div id=‘father‘>  // 标签为p的元素的父级元素是id为father的元素,祖先元素为id为father和ancestor的元素
          <p><span>0</span></p>  // id为father的元素的子级元素是标签为p的元素,后代元素为标签p与span的元素
          <p>1</p>
    </div>
</div>

统一好关系名称之后,再探讨元素之间的关系就不会感觉混乱。

现在有如下代码:

<form>
    <label>Name:</label>
    <input name="name" />
    <fieldset>
        <label>Newsletter:</label>
        <input name="firstletter" />      <input name="secondletter" />     </fieldset>
    <input name="none" />
</form>

选择标签为form的所有子级input元素:

$(‘form>input‘); // 选择标签为from的元素下的所有标签为input的子级元素,即name=“name”,name=“none”的元素

选择标签为form的所有的后代input元素:

$(‘form input‘); // 选择标签为from的元素下的所有标签为input的后代元素,即name=“name”,name=“none”,name=“firstletter”,name=“secondletter”的元素

也可以选择符合条件的同级元素(同级元素中的第一个):

$(‘label+input‘); // 选择标签为label的同级元素中,标签为input的元素中的第一个,即name=“name”,name=“firstletter”的元素

也可以选择所有符合条件的同级元素:

$(‘label~input‘); // 选择标签为label的同级元素中,所有标签为input的元素,即name=“name”,name=“firstletter”,name=“secondletter”,name=“none”的元素

选择后代元素中包含选定元素的元素:

<div>
    <p><span>Hello</span></p>
</div>
<div>Hello again!</div>
$(‘div:has(span)‘) // 选择所有后代元素中包含span元素的div元素

---------------->此文转发!
时间: 2024-10-25 01:32:02

Jquery:小知识;的相关文章

Jquery小知识

1. $(document).ready(function(){ $('form').find("input[type=textarea], input[type=password], textarea").each(function(ev) { if(!$(this).val()) { $(this).attr("placeholder", "Type your answer here"); } }); });//获取属性How can I s

JS,JQuery小知识

http://blog.163.com/[email protected]/blog/static/28896414201112252456459/?suggestedreading&wumii

jquery小知识(笔记)

1.判断元素是否绑定click事件: $("#div2").click(function(){ alert("div2"); }); events=$("#div2").data("events"); f(events&&events["click"]){ //存在click事件 } 2.使用字面量给元素添加属性: var a=$("<a>A</a>&quo

JQuery基础知识(1)

JQuery基础知识(1) 对JQuery学习中遇到的小细节进行了整理和总结 1.JQuery hide()和show()方法,分别对选中的元素进行隐藏和显示,语法:hide()和show分别有对应的参数,即hide(speed);隐藏的速度进行了限定.hide(1000)/show(1000); 2.JQuery toggle()方法用来切换hide()和show();可以用speed参数进行控制显示和隐藏的速度. JQuery的淡入淡出 1.JQuery fadeIn();此方法可以携带不同

iOS 小知识-tips

--->1<--- arc的项目中使用非arc代码,则添加-fno-objc-arc: 非arc项目中使用arc代码,则添加-fobjc-arc. --->2<--- 实用的类 NSKeyedArchiver [UIScreen mainScreen] [UIDevice currentDevice] [UIFont familyNames] [UIApplication sharedApplication] [NSUserDefaults standardUserDefaults

Linux 小知识翻译 - 「syslog」

这次聊聊「syslog」. 上次聊了「日志」(lgo).这次说起syslog,一看到log(日志)就明白是怎么回事了.syslog是获取系统日志的工具. 很多UINIX系的OS都采用了这个程序,它承担了「获取系统全部的日志」这个维持系统正常运行的重要任务. syslog的本体是「syslogd」这个daemon(一般翻译成守护进程),常驻内存中获取日志. syslog的特点是可以通过配置文件「/etc/syslog.conf」,对「哪种应用程序?哪种重要度的信息?记录在哪个文件中?」等进行细致的

Linux 小知识翻译 - 「日志」(log)

这次聊聊「日志」. 「日志」主要指系统或者软件留下的「记录」.出自表示「航海日志」的「logbook」. 经常听说「出现问题的时候,或者程序没有安装自己预期的来运行的时候,请看看日志!」. 确实,记录了系统和软件详细运行情况的「日志」是信息的宝库,通过日志来解决问题的事例也非常多. 但事实上,「无论如何也不会看日志」的用户也有很多.理由很简单,日志的信息量非常大,全部用眼睛来看的话是非常吃力的. 而且,英语写的日志也会让英文不好的人敬而远之. 虽说「要养成用眼睛来看日志的习惯」,但实行起来却非常

Linux 小知识翻译 - 「编译器和解释器」

这次聊聊「编译器和解释器」. 编程语言中,有以C为代表的编译型语言和以Perl为代表的解释型语言.不管是哪种,程序都是以人类能够理解的形式记录的,这种形式计算机是无法理解的. 因此,才会有编译器和解释器. 对于编译型语言,是使用编译器将人类可读的代码转换为机器能够理解的「机器语言」文件,然后通过执行这个「机器语言」文件来实现程序的执行. 另一方面,对于解释型语言,是使用解释器将人类可读的代码逐行解释,一边解释一边执行这个程序.(这里的解释是将代码解释成机器语言,让计算机能够理解) 甚至有的语言既

Linux 小知识翻译 - 「补丁」(patch)

这次,聊聊补丁. 当有bug或者安全漏洞的时候,就会发布补丁.打上补丁之后,就能解决相应的bug或者安全漏洞. 那么,「补丁」到底是什么呢? 「补丁」只有少量的代码,一般都是对程序的一部分进行更新或者追加,包括bug修正,安全漏洞修正,功能追加或者变更等等.当然,只有「补丁」是无法运行的. 即,只有将「补丁」附加到原来的程序中,更新原来的程序后,才能运行. 「补丁(patch)」本来是指「打补丁用的小布头」.「patch」正是为了补足现有的程序,堵住程序漏洞的「布头」. 打「补丁」的时候需要用到