Jquery:小知识;
Jquery:小知识;
上一节的遗留问题,关于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元素 ---------------->此文转发!
Jquery:小知识;的更多相关文章
- JQuery小知识
一.禁用鼠标右键 $(document).ready(function() { $(document).bind("contextmenu", function(e) { retu ...
- JS,JQuery小知识
http://blog.163.com/wumingli456@126/blog/static/28896414201112252456459/?suggestedreading&wumii
- jquery 小知识
$("p:eq(0)") :表p标签的第一个元素 $("p:eq(1)") :表p标签的第二个元素
- s性能优化方面的小知识
总结的js性能优化方面的小知识 前言 一直在学习javascript,也有看过<犀利开发Jquery内核详解与实践>,对这本书的评价只有两个字犀利,可能是对javascript理解的还不够 ...
- JQuery基础知识(1)
JQuery基础知识(1) 对JQuery学习中遇到的小细节进行了整理和总结 1.JQuery hide()和show()方法,分别对选中的元素进行隐藏和显示,语法:hide()和show分别有对应的 ...
- 蓝牙Bluetooth技术小知识
蓝牙Bluetooth技术以及广泛的应用于各种设备,并将继续在物联网IoT领域担任重要角色.下面搜集整理了一些关于蓝牙技术的小知识,以备参考. 蓝牙Bluetooth技术始创于1994年,其名字来源于 ...
- HTML+CSS中的一些小知识
今天分享一些HTML.CSS的小知识,希望能够对大家有所帮助! 1.解决网页乱码的问题:最重要的是要保证各个环节的字符编码一致! (1)编辑器的编辑环境的字符集(默认字符集):Crtl+U 常见的编码 ...
- 10个jQuery小技巧
收集的10个 jQuery 小技巧/代码片段,可以帮你快速开发. 1.返回顶部按钮 你可以利用 animate 和 scrollTop 来实现返回顶部的动画,而不需要使用其他插件. $('a.top' ...
- iOS APP开发的小知识(分享)
亿合科技小编发现从2007年第一款智能手机横空出世,由此开启了人们的移动智能时代.我们从一开始对APP的陌生,到现在的爱不释手,可见APP开发的出现对我们的生活改变有多巨大.而iOS AP ...
随机推荐
- Get item by sharepoint web service jquery
对于sp2010,在ie浏览器中这个代码无法生效,只有chrome可以生效. //获取附件id function GetAttachments(listName) { var soapEnv = '& ...
- SPS中使用JSOM发邮件
直接上代码了: function ShowMailDialog() { $.ajax({ url: siteurl + "/_api/contextinfo", method: & ...
- Android自带的theme
android:theme="@android:style/Theme.Dialog" 将一个Activity显示为能话框模式 android:theme="@andro ...
- Hbase Java API详解
HBase是Hadoop的数据库,能够对大数据提供随机.实时读写访问.他是开源的,分布式的,多版本的,面向列的,存储模型. 在讲解的时候我首先给大家讲解一下HBase的整体结构,如下图: HBase ...
- iOS使用Charles(青花瓷)抓包并篡改返回数据图文详解
写本文的契机主要是前段时间有次用青花瓷抓包有一步忘了,在网上查了半天也没找到写的完整的教程,于是待问题解决后抽时间截了图,自己写一遍封存在博客园中以便以后随时查阅. charles又名青花瓷,在iOS ...
- UIWebView的应用和其中的JS与OC间传值
现在有很多的应用已经采用了WebView和html语言结合的开发模式.html5一直很火因为一份代码可以在多个平台上运用啊,效果各不相同都很美观,也越来越有一些公司直接招后台程序员和html5程序员, ...
- 【即时通讯】XMPP调试与简单使用
上篇讲了[即时通讯]即时通讯及XMPP概述及环境配置,接下来我们就要进行调试,看看是否可用! 在测试之前我们需要先事先保存一些东西,以便后面使用 —— 登录openfire后台 ——获取服务器名和端口 ...
- Android对话框
这周过的实在是艰辛,自打这周二起我的本本就开始闹"罢工",最后还是重装系统了事. . . 只是可怜了我的那些被格了的软件(悲伤辣么大)! 往事不要再提,人生几度风雨... 简 ...
- Xcode常见错误汇总
1.error: macro names must be identifiers YourProject_prefix.pch 原因: 因为你弄脏了预处理器宏,在它处于<Multiple Val ...
- C语言中的运算符
1. 在C语言中运算符包括:算术运算符.关系运算符.赋值运算符.逻辑运算符 2.用运算符把变量.常量连接起来的式子就是表达式 3.我们阅读一个表达式,从表达式的功能和表达式的值来看 4. 算术运算符和 ...