Mootools 1.2教程(3) 数组使用简介


Posted in Javascript onSeptember 14, 2009

今天,我们在来看看如何使用数组来管理DOM元素。
基本方法
.each();
在处理数组时,.each();方法是你最好的朋友。它提供了一种很容易的方法来遍历数组的每个元素,如果有需要还可以对其中的元素进行任何逻辑处理。例如,我们可以假设你需要为页面中的每个div对象调用alert方法:
参考代码:

$$('div').each(function() { 
alert('a div'); 
});

如果使用下面的HTML代码,上面的JavaScript代码将弹出两个alert对话框,每个div一个。
参考代码:
<div>One</div> 
<div>Two</div>

.each();方法不需要你使用$$方法。创建一个数组的另一种方式(就像我们昨天讲到过的)是使用.getElements();方法。
参考代码:
$('body_wrap').getElements('div').each(function() { 
alert('a div'); 
});

参考代码:
<div id="body_wrap"> 
<div>One</div> 
<div>Two</div> 
</div>

还有另外一种方法来完成这个相同的任务,就是把这个数组赋值给一个变量,然后对那个变量使用.each();方法:
参考代码:
// 首先你需要通过语句”var VARIABLE_NAME“来声明一个变量 
// 然后用等于运算符”=“来给这个变量赋值 
// 在这个例子中,是一个包含div元素的数组 
var myArray = $('body_wrap').getElements('div'); 
// 现在你就可以把这个变量当数组选择器使用了 
myArray.each(function() { 
alert('a div'); 
});

最后,如果你可能想把你的函数从选择器中独立出来。我们会在明天的关于使用函数的教程中更深入地讲解这个问题。不过,现在我们可以创建一个非常简单的示例:
参考代码:
var myArray = $('body_wrap').getElements('div'); 
// 要创建一个函数,你可以像刚才一样声明一个变量,然后给它命名 
// 在等号后面使用”function()“来声明这个变量为一个函数 
// 最后,在 { 和 }之间写入你的函数代码 
var myFunction = function() { 
alert('a div'); 
}; 
// 现在你就可以在.each();.方法里面调用刚才的函数了 
myArray.each(myFunction);

注意:当你像刚才那样在.each();.方法里面调用函数时,你不需要给函数名加上引号。
复制一个数组
$A
MooTools提供了一个简单的方式——通过$A函数来复制一个数组。让我们像刚才那样使用变量创建一个数组:
参考代码:
// 创建你的数组变量 
var myArray = $('body_wrap').getElements('div');

复制一个数组(创建该数组的副本):
参考代码:
// 建立一个新的变量名,命名为”myCopy“,然后把”myArray“的副本赋值给它 
var myCopy = $A(myArray );

从数组中获取指定的元素
.getLast();
.getLast();方法返回数组中最后一个元素。首先我们建立一个数组:
参考代码:
var myArray = $('body_wrap').getElements('div');

现在我们可以从这个数组中获取最后一个元素:
参考代码:
var lastElement = myArray.getLast();

变量lastElement现在的值就是数组myArray中的最后一个元素了。
.getRandom();
和.getLast();一样,不过它随机从数组中取得一个元素:
参考代码:
var randomElement = myArray.getRandom();

变量randomElement现在的值就是从数组myArray中随机选取的一个元素了。
向数组中添加一个元素
.include();
通过这个方法,你可以给数组添加另外一个元素。只要把元素选择器传给.include();方法,它就会包含到你的数组中。我们使用下面的HTML代码:
参考代码:
<div id="body_wrap"> 
<div>one</div> 
<div>two</div> 
<span id="add_to_array">add to array</span> 
</div>

我们可以像以前那样调用”body_wrap“下面的所有div一样来创建一个数组:
参考代码:
var myArray = $('body_wrap').getElements('div');

要把另外一个元素添加到这个数组中,首先你需要把这个元素赋值给一个变量,然后使用include方法:
参考代码:
// 首先把你的元素赋值给一个变量 
var newToArray = $('add_to_array'); 
// 然后把它添加到数组 
myArray.include(newToArray);

现在,这个数组就同时包含div和span元素了。
.combine();
和.include();方法一样,不过它可以让你把一个数组添加到一个已经存在的数组中,而不用担心有重复的内容。假设我们现在从下面的HTML中取得了两个数组:
参考代码:
<div id="body_wrap"> 
<div>one</div> 
<div>two</div> 
<span class="class_name">add to array</span> 
<span class="class_name">add to array, also</span> 
<span class="class_name">add to array, too</span> 
</div>

我们可以这样建立两个数组:
参考代码:
// 就像我们以前那样建立你的数组 
var myArray= $('body_wrap').getElements('div'); 
// 然后建立一个所有CSS类名为.class_name的元素数组 
var newArrayToArray = $$('.class_name');

现在我们可以使用.combine();方法来合并两个数组,这个方法会自己处理重复的元素,因此我们不需要处理:
参考代码:
// 把数组newArrayToArray合并到数组myArray中 
myArray.combine(newArrayToArray );

现在myArray就包含了newArraytoArray中的所有元素。
代码示例
数组可以让你遍历包含所有项目的列表,并对每个元素执行相同的代码。在这个例子中,注意变量”item“作为当前元素的替代符的使用。
参考代码:
// 创建一个数组,这个数组包含”body_wrap“里面所有CSS类名为.class_name的元素 
var myArray = $('body_wrap').getElements('.class_name'); 
// 首先建立一个要添加到数组中的元素 
var addSpan = $('addtoarray'); 
// 然后建立一个要合并的数组 
var addMany = $$('.addMany'); 
// 现在我们把元素addSpan加入到数组中 
myArray.include(addSpan); 
// 然后合并数组addMany到myArray中 
myArray.combine(addMany); 
// 建立一个需要对数组中的每个元素都要执行的函数 
var myArrayFunction = function(item) { 
// item现在指向数组中的当前元素 
item.setStyle('background-color', '#eee'); 
} 
// 现在对数组中的每个项目调用myArrayFunction函数 
myArray.each(myArrayFunction);

参考代码:
<div id="body_wrap"> 
<div class="class_name">one</div><!-- this has gray background --> 
<div>two</div> 
<div class="class_name">three</div><!-- this has gray background --> 
<span id="addtoarray">add to array</span> <!-- this has gray background --> 
<br /><span class="addMany">one of many</span> <!-- this has gray background --> 
<br /><span class="addMany">two of many</span> <!-- this has gray background --> 
</div>

延伸学习

这个教程并没有打算涵盖你能对数组做的全部事情,但是希望能够给你一个参考,告诉你MooTools提供了一些什么功能。要学习更多关于数组的东西,请仔细阅读这些内容:

  • 文档中的数组部分
  • 这个页面中有许多关于JavaScript数组的信息

下载一个包含你开始所需要的所有东西的zip包

包括一个简单的html文件、MooTools 1.2核心库、一个外部JavaScript文件、一个css文件和上面的所有例子。

Javascript 相关文章推荐
js 替换
Feb 19 Javascript
神奇的代码 通杀各种网站-可随意修改复制页面内容
Jul 17 Javascript
IE的有条件注释判定IE版本详解(附实例代码)
Jan 04 Javascript
jquery实现简单手风琴菜单效果实例
Jun 13 Javascript
JS实现简单的图书馆享元模式实例
Jun 30 Javascript
jQuery判断浏览器并动态调整select宽度的方法
Mar 02 Javascript
详解bootstrap的modal-remote两种加载方式【强化】
Jan 27 Javascript
JS html时钟制作代码分享
Mar 03 Javascript
脚手架vue-cli工程webpack的基本用法详解
Sep 29 Javascript
jQuery实现获取当前鼠标位置并输出功能示例
Jan 05 jQuery
jQuery 常用特效实例小结【显示与隐藏、淡入淡出、滑动、动画等】
May 19 jQuery
5个实用的JavaScript新特性
Jun 16 Javascript
Mootools 1.2教程(2) DOM选择器
Sep 14 #Javascript
MooTools 1.2介绍
Sep 14 #Javascript
IE与Firefox在JavaScript上的7个不同写法小结
Sep 14 #Javascript
JavaScript 函数调用规则
Sep 14 #Javascript
prototype与jquery下Ajax实现的差别
Sep 13 #Javascript
JS 参数传递的实际应用代码分析
Sep 13 #Javascript
javascript类继承机制的原理分析
Sep 12 #Javascript
You might like
PHP5 安装方法
2007/01/15 PHP
Laravel中前端js上传图片到七牛云的示例代码
2017/09/04 PHP
对于Laravel 5.5核心架构的深入理解
2018/02/22 PHP
jquery提升性能最佳实践小结
2010/12/06 Javascript
seajs1.3.0源码解析之module依赖有序加载
2012/11/07 Javascript
JavaScript模块随意拖动示例代码
2014/05/27 Javascript
javascript中的return和闭包函数浅析
2014/06/06 Javascript
jQuery中:focus选择器用法实例
2014/12/30 Javascript
JS+CSS实现淡入式焦点图片幻灯切换效果的方法
2015/02/26 Javascript
jQuery实现渐变下拉菜单的简单方法
2015/03/11 Javascript
移动端js图片查看器
2016/11/17 Javascript
微信小程序 限制1M的瘦身技巧与方法详解
2017/01/06 Javascript
JavaScript判断浏览器及其版本信息
2017/01/20 Javascript
ES6(ECMAScript 6)新特性之模板字符串用法分析
2017/04/01 Javascript
vue2.0 datepicker使用方法
2018/02/04 Javascript
JavaScript直接调用函数与call调用的区别实例分析
2020/05/22 Javascript
jquery实现鼠标悬浮弹出气泡提示框
2020/12/23 jQuery
[05:31]DOTA2上海特级锦标赛主赛事第三日RECAP
2016/03/05 DOTA
Python中暂存上传图片的方法
2015/02/18 Python
在Linux下调试Python代码的各种方法
2015/04/17 Python
Python编程实现两个文件夹里文件的对比功能示例【包含内容的对比】
2017/06/20 Python
django解决跨域请求的问题详解
2019/01/20 Python
Python获取网段内ping通IP的方法
2019/01/31 Python
Python提取特定时间段内数据的方法实例
2019/04/01 Python
详解python中递归函数
2019/04/16 Python
python 函数中的内置函数及用法详解
2019/07/02 Python
django的分页器Paginator 从django中导入类
2019/07/25 Python
浅谈pytorch池化maxpool2D注意事项
2020/02/18 Python
Python网页解析器使用实例详解
2020/05/30 Python
浅谈anaconda python 版本对应关系
2020/10/07 Python
使用HTML5 IndexDB存储图像和文件的示例
2018/11/05 HTML / CSS
德购商城:德国进口直邮商城
2017/06/13 全球购物
如何写自我评价?自我评价写什么好?
2014/03/14 职场文书
开服装店计划书
2014/08/15 职场文书
党员群众路线学习心得体会
2014/11/04 职场文书
简单聊聊TypeScript只读修饰符
2022/04/06 Javascript