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元素

转自互联网

在JQ中关于this的更多相关文章

  1. jq中数组应用的错误

    js中数组可以这样使用: <ul id="ul"> <li value="1">s</li> <li>f< ...

  2. JQ中mouseover和mouseenter的区别

    我最近也在学习JQuery,所以最近对JQ中的一些小问题进行总结,方便学习. 在对于刚开始学习JQ的初学者来说,mouseover事件和mouseenter事件总是傻傻分不清楚,毕竟刚开始学习的时候, ...

  3. JS模式:jq中简单的模式--》采摘自js设计(tomxu_version)

    <!DOCTYPE html> <html> <head> <title></title> </head> <body&g ...

  4. JQ中的clone()方法与DOM中的cloneNode()方法

    JQ中的clone()方法与DOM中的cloneNode()方法 cloneNode()定义和用法 cloneNode()方法创建节点的拷贝,并返回该副本. 语法: node.cloneNode(de ...

  5. jq中的ajax

    jq对ajax进行了封装,在jq中$.ajax()方法是最底层的方法,第二层是load() , get() , post()方法,第三层是$.getScript()和$.getJSON().基本第二种 ...

  6. jq中的$操作符与其他js框架冲突

    解决办法: jq中存在方法:noConflict() 可返回对 jQuery 的引用. 使用示例: var jq = $.noConflict(); jq(document).ready(functi ...

  7. jq中的isArray方法分析,如何判断对象是否是数组

    <!DOCTYPE html> <html> <head> <title>jq中的isArray方法分析</title> <meta ...

  8. JQ中$(window).load和$(document).ready区别与执行顺序

    JQ中的$(document).ready()大家应该用的非常多,等同于$(function(){}),基本每个JS脚本中都有这个函数的出现有时甚至会出现多个,那么另一个加载函数$(window).l ...

  9. [转]JQ中$(window).load和$(document).ready区别与执行顺序

    一.$(window).load().window.onload=function(){}和$(document).ready()方法的区别 1.$(window).load() 和window.on ...

  10. jq中append()、prepend()、after()、before()的区别

    jq中append().prepend().after().before()的区别详解 .append() - 在被选元素的结尾插入内容(内容的结尾,比如说有个a标签,则是在</a>这个标 ...

随机推荐

  1. RadioGroup 和 ViewPager 绑定 实现切换

    package com.jereh.helloworld.activity.day12; import android.app.Activity; import android.os.Bundle; ...

  2. 【逆向篇】分析一段简单的ShellCode——从TEB到函数地址获取

    其实分在逆向篇不太合适,因为并没有逆向什么程序. 在http://www.exploit-db.com/exploits/28996/上看到这么一段最简单的ShellCode,其中的技术也是比较常见的 ...

  3. Axure的学习

    这两天开始学习Axure,首先做的是下载Axure的7.0版本,然后汉化,可以百度找.不过我在开始学习时也遇到一些问题.在开始添加元件库时还是很顺利的,不过在我发布的时候,我发现了一些问题.发布一开始 ...

  4. js基础3

    内置对象 内置对象就是JS提供的一套工具箱,我们通过内置可以很方便的进行一些操作. Math对象: Math.ceil() //向上取整,天花板 Math.floor() //向下取整,地板 Math ...

  5. Ansible-playbook批量部署,更新war脚本,可以再完善----后续再update

    - name: install tomcat admin hosts: all sudo: True vars: war_file: /root/test.war tomcat_root: /data ...

  6. 异步调用window.open时被浏览器阻止新窗口解决方案

    var wyWindow = window.open('_blank');$http.post($rootScope.baseUrl + '/Interface0231A.ashx', { userF ...

  7. Android app应用多语言切换功能实现

    最近在做一个多语言切换的功能,类似于微信的语言切换,搜了下资料基本上都是以下这种: 1. 实现的效果 和微信类似,在设置界面打开切换语言的界面,选择语言后重启 HomeActivity,语言切换完成, ...

  8. 判断是PC端还是移动端

    http://detectmobilebrowsers.com/ 此网站提供了各种编程语言(包括 Apache.ASP.ASP.NET.C#. IIS. JSP. JavaScript. jQuery ...

  9. WinForm窗体 SSK 界面的使用

    1.下载 SSk文件 找到  IrisSkin2.dll 文件和.SSK结尾的文件    为了防止万一粘贴到项目的bin>Debug下面 2. 打开工具箱   添加一个选项卡 3. 添加选择项& ...

  10. CSS 使用母版页的内容页如何调用css和javascript

    方案一: 把所有的css样式和javascript函数放到母版页的<head></head>中,我觉得这样做的弊端就是导致母版页的<head></head&g ...