jquery 学习之一 对象访问


Posted in Javascript onNovember 23, 2010

each()

each(callback)

以每一个匹配的元素作为上下文来执行一个函数。
意味着,每次执行传递进来的函数时,函数中的this关键字都指向一个不同的DOM元素(每次都是一个不同的匹配元素)。

而且,在每次执行函数时,都会给函数传递一个表示作为执行环境的元素在匹配的元素集合中所处位置的数字值作为参数(从零开始的整形)。

返回 'false' 将停止循环 (就像在普通的循环中使用 'break')。返回 'true' 跳至下一个循环(就像在普通的循环中使用'continue')。

Execute a function within the context of every matched element.
This means that every time the passed-in function is executed (which is once for every element matched) the 'this' keyword points to the specific DOM element.

Additionally, the function, when executed, is passed a single argument representing the position of the element in the matched set (integer, zero-index).

Returning 'false' from within the each function completely stops the loop through all of the elements (this is like using a 'break' with a normal loop). Returning 'true' from within the loop skips to the next iteration (this is like using a 'continue' with a normal loop).

返回值

jQuery

参数

callback (Function) : 对于每个匹配的元素所要执行的函数

示例

迭代两个图像,并设置它们的 src 属性。注意:此处 this 指代的是 DOM 对象而非 jQuery 对象。

HTML 代码:

<img/><img/>

jQuery 代码:

$("img").each(function(i){
   this.src = "test" + i + ".jpg";
 });

结果:

[ <img src="test0.jpg" />, <img src="test1.jpg" /> ]

如果你想得到 jQuery对象,可以使用 $(this) 函数。

jQuery 代码:

$("img").each(function(){
  $(this).toggleClass("example");
});

你可以使用 'return' 来提前跳出 each() 循环。

HTML 代码:

<button>Change colors</button><span></span> <div></div> <div></div><div></div> <div></div><div id="stop">Stop here</div> <div></div><div></div><div></div>

jQuery 代码:

$("button").click(function () { $("div").each(function (index, domEle) {  // domEle == this  $(domEle).css("backgroundColor", "yellow");  if ($(this).is("#stop")) {  $("span").text("Stopped at div index #" + index);  return false;  } });});
--------------------------------------------------------------------------------------------------------------------------------

size()

jQuery 对象中元素的个数。
这个函数的返回值与 jQuery 对象的'length' 属性一致。
The number of elements in the jQuery object.
This returns the same number as the 'length' property of the jQuery object.

返回值

Number

示例

计算文档中所有图片数量

HTML 代码:

<img src="test1.jpg"/> <img src="test2.jpg"/>

jQuery 代码:

$("img").size();

结果:

2
-------------------------------------------------------------------------------------------------------------------------

length

jQuery 对象中元素的个数。
当前匹配的元素个数。 size 将返回相同的值。
The number of elements in the jQuery object.
The number of elements currently matched. The size function will return the same value.

返回值

Number

示例

计算文档中所有图片数量

HTML 代码:

<img src="test1.jpg"/> <img src="test2.jpg"/>

jQuery 代码:

$("img").length;

结果:

2
---------------------------------------------------------------------------------------------------------------------------------------

get()

取得所有匹配的 DOM 元素集合。

这是取得所有匹配元素的一种向后兼容的方式(不同于jQuery对象,而实际上是元素数组)。

 

如果你想要直接操作 DOM 对象而不是 jQuery 对象,这个函数非常有用。

Access all matched DOM elements.
This serves as a backwards-compatible way of accessing all matched elements (other than the jQuery object itself, which is, in fact, an array of elements). It is useful if you need to operate on the DOM elements themselves instead of using built-in jQuery functions.

返回值

Array<Element>

示例

选择文档中所有图像作为元素数组,并用数组内建的 reverse 方法将数组反向。

HTML 代码:

<img src="test1.jpg"/> <img src="test2.jpg"/>

jQuery 代码:

$("img").get().reverse();

结果:

[ <img src="test2.jpg"/> <img src="test1.jpg"/> ]
---------------------------------------------------------------------------------------------------------------------------------------

get(index)

取得其中一个匹配的元素。 num表示取得第几个匹配的元素。
这能够让你选择一个实际的DOM 元素并且对他直接操作,而不是通过 jQuery 函数。$(this).get(0)与$(this)[0]等价。
Access a single matched DOM element at a specified index in the matched set.
This allows you to extract the actual DOM element and operate on it directly without necessarily using jQuery functionality on it. This function called as $(this).get(0) is the equivalent of using square bracket notation on the jQuery object itself like $(this)[0].

返回值

Element

参数

index (Number) :取得第 index 个位置上的元素

示例

 

HTML 代码:

<img src="test1.jpg"/> <img src="test2.jpg"/>

jQuery 代码:

$("img").get(0);

结果:

[ <img src="test1.jpg"/> ]
---------------------------------------------------------------------------------------------------------------------------------------

index(subject)

搜索与参数表示的对象匹配的元素,并返回相应元素的索引值值。
如果找到了匹配的元素,从0开始返回;如果没有找到匹配的元素,返回-1。
Searches every matched element for the object and returns the index of the element, if found, starting with zero.
Returns -1 if the object wasn't found.

返回值

Number

参数

subject (Element) : 要搜索的对象

示例

返回ID值为foobar的元素的索引值值。

HTML 代码:

<div id="foobar"><b></b><span id="foo"></span></div>

jQuery 代码:

$("*").index($('#foobar')[0])

结果:

5
Javascript 相关文章推荐
js截取函数(indexOf,join等)
Sep 01 Javascript
使用jquery实现简单的ajax
Jul 08 Javascript
详谈jQuery操纵DOM元素属性 attr()和removeAtrr()方法
Jan 22 Javascript
JavaScript数组去重的3种方法和代码实例
Jul 01 Javascript
JS创建对象几种不同方法详解
Mar 01 Javascript
JS 实现倒计时数字时钟效果【附实例代码】
Mar 30 Javascript
js发送短信倒计时的简单实现方法
Sep 08 Javascript
解决layer弹层遮罩挡住窗体的问题
Aug 17 Javascript
引入外部js脚本加载慢与页面白屏问题的解决
Dec 10 Javascript
解决微信小程序中转换时间格式IOS不兼容的问题
Feb 15 Javascript
使用layui的layer组件做弹出层的例子
Sep 27 Javascript
微信小程序如何实现五星评价功能
Oct 15 Javascript
boxy基于jquery的弹出层对话框插件扩展应用 弹出层选择器
Nov 21 #Javascript
IE6下出现JavaScript未结束的字符串常量错误的解决方法
Nov 21 #Javascript
基于jquery的滑动样例代码
Nov 20 #Javascript
jquery $.ajax()取xml数据的小问题解决方法
Nov 20 #Javascript
简单实用的js调试logger组件实现代码
Nov 20 #Javascript
扩展javascript的Date方法实现代码(prototype)
Nov 20 #Javascript
javascript AOP 实现ajax回调函数使用比较方便
Nov 20 #Javascript
You might like
几款免费开源的不用数据库的php的cms
2010/12/19 PHP
用PHP读取和编写XML DOM的实现代码
2011/02/03 PHP
在PHP中使用redis
2013/11/04 PHP
php中文语义分析实现方法示例
2019/09/28 PHP
PHP开发API接口签名生成及验证操作示例
2020/05/27 PHP
js removeChild 障眼法 可能出现的错误
2009/10/06 Javascript
起点页面传值js,有空研究学习下
2010/01/25 Javascript
基于Jquery的将DropDownlist的选中值赋给label的实现代码
2011/05/06 Javascript
js原型继承的两种方法对比介绍
2014/03/30 Javascript
Jquery实现仿腾讯娱乐频道焦点图(幻灯片)特效
2015/03/06 Javascript
JavaScript实现常用二级省市级联下拉列表的方法
2015/03/25 Javascript
AngularJS Module方法详解
2015/12/08 Javascript
VUEJS实战之构建基础并渲染出列表(1)
2016/06/13 Javascript
原生js实现轮播图
2017/02/27 Javascript
vue.js2.0点击获取自己的属性和jquery方法
2018/02/23 jQuery
vue2.0+vuex+localStorage代办事项应用实现详解
2018/05/31 Javascript
详解从Vue-router到html5的pushState
2018/07/21 Javascript
NodeJS如何实现同步的方法示例
2018/08/24 NodeJs
vue服务端渲染缓存应用详解
2018/09/12 Javascript
JavaScript利用键盘码控制div移动
2020/03/19 Javascript
如何使用JS console.log()技巧提高工作效率
2020/10/14 Javascript
Python检测生僻字的实现方法
2016/10/23 Python
Python图像处理之图像的缩放、旋转与翻转实现方法示例
2019/01/04 Python
pygame实现俄罗斯方块游戏(基础篇1)
2019/10/29 Python
python 画条形图(柱状图)实例
2020/04/24 Python
python 实现非极大值抑制算法(Non-maximum suppression, NMS)
2020/10/15 Python
python中的yield from语法快速学习
2020/11/06 Python
html5中audio支持音频格式的解决方法
2018/08/24 HTML / CSS
Hello Molly美国:女性时尚在线
2019/08/26 全球购物
项目负责人任命书
2014/06/04 职场文书
新闻报道策划方案
2014/06/11 职场文书
员工工作能力评语
2014/12/31 职场文书
学校捐款活动总结
2015/05/09 职场文书
企业计划生育责任书
2015/05/09 职场文书
感恩教育观后感
2015/06/17 职场文书
中学后勤工作总结2015
2015/07/22 职场文书