Mootools 1.2教程(2) DOM选择器


Posted in Javascript onSeptember 14, 2009

如果你还没有准备好,请先阅读上一篇《Mootools 1.2教程(1)——MooTools介绍》。我们讲了怎么引用MooTools 1.2以及怎么在domready里面调用你的脚本。
今天开始本系列教程的第2讲。在这一讲中,我们会学习几种选择HTML元素的方法。在许多方面,这是MooTools用得最多最基本的。毕竟,要创建一个基于HTML元素的交互性用户体验,你必须首先把它们掌握在手中。
基本的方法
$();
$函数是MooTools中基本的选择器。你可以通过它来根据一个ID选择DOM元素。
参考代码:

// 选择ID为”body_wrap“的元素 
$('body_wrap');

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

.getElement();
.getElement();扩展了$方法,可以让你简化你的选择操作。例如,你可以通过$方法来选择ID为”body_wrap“的元素,然后选择第一个子节点。.getElement();只选择一个元素,如果有多个符合要求的元素则返回第一个元素。如果你给.getElement();方法一个CSS类名作为参数,你就会得到第一个有这个CSS类名的元素,而不是函数所有元素的数组。要选择多个元素,则可以使用下面的.getElements();方法。
参考代码:
// 选择ID为”body_wrap“的元素下面的第一个链接 
$('body_wrap').getElement('a'); 
// 选择ID为”body_wrap“的元素下面的ID为”special_anchor“的元素 
$('body_wrap').getElement('#special_anchor'); 
// 选择ID为”body_wrap“的元素下面第一个CSS类名为”special_anchor_class“的元素 
$('body_wrap').getElement('.special_anchor_class');

参考代码:
<div id="body_wrap"> 
<a href="#">anchor</a> 
<a href="#">another anchor</a> 
<a id="special_anchor" href="#">special anchor</a> 
<a class="special_anchor_class" href="#">special anchor</a> 
<a class="special_anchor_class" href="#">another special anchor</a> 
</div>

$$();
$$函数可以可以让你快速选择多个元素,并组成一个数组(一种你可以操作、获取和以任何方式重新排序的列表)。你可以通过标签名(如div、a、img等)、或者ID或者是他们的各种组合来选择多个元素。就像一个读者指出的那样,你可以用$$做很多事情,远远超出我们这里所介绍的。
参考代码:
// 选择这个页面中的所有div 
$$('div'); 
// 选择ID为”id_name的元素和所有的div 
$$('#id_name', 'div');

参考代码:
<div> 
<div>a div</div> 
<span id="id_name">a span</span> 
</div>

.getElements();
.getElements();和.getElement();非常类似,不过它返回所有符合要求的元素,并组成一个数组。你可以想使用.getElement();方法那样使用.getElements();。
参考代码:
// 选择ID为”body_wrap“的元素下面的所有链接 
$('body_wrap').getElements('a'); 
// 选择ID为”body_wrap“的元素下面的所有CSS类名为”special_anchor_class“的子元素 
$('body_wrap').getElements('.special_anchor_class');

参考代码:
<div id="body_wrap"> 
<a href="#">anchor</a> 
<a href="#">another anchor</a> 
<a class="special_anchor_class" href="#">special anchor</a> 
<a class="special_anchor_class" href="#">another special anchor</a> 
</div>

用运算符包含和排除结果
运算符
MooTools 1.2支持几种运算符,可以让你进一步精简你的选择操作。你可以在.getElements();中使用这些运算符来包含或者排除特定的结果。MooTools支持4种运算符,每一种都可以用来通过名字(name)选择一个input元素。
= : 等于
参考代码:
//选择name为”phone_number“的input元素
$('body_wrap').getElements('input[name=phone_number]');
^= : 以……开始
参考代码:
// 选择name以”phone“开头的input元素
$('body_wrap').getElements('input[name^=phone]');
$= : 以……结束
参考代码:
// 选择name以数字(number)结束的input元素
$('body_wrap').getElements('input[name$=number]');
!= : 不等于
参考代码:
// 选择名字不等于”address“的input元素
$('body_wrap').getElements('input[name!=address]');
参考代码:
<div id="body_wrap">
<input name="address" type="text" />
<input name="phone_number" type="text" /> <!-- 上面的所有示例代码都将选中这个元素 -->
</div>
(Fdream注:input在这里只是作为一个例子,你同样可以使用这种方式选择其他元素,比如div、a等等。)
要使用运算符,你必须首先指定元素的类型(比如这里的input),然后指定你要过滤的属性(比如这里的name),再加上你的 运算符,最后选择你的过滤字符串。
基于元素顺序的选择器
even(偶数选择)
通过这个简单的选择器,你可以选择序号为偶数的元素。注意:这个选择器从0开始计数,因此第一个元素是偶数序的。
参考代码:
// 选择序号为偶数的div
$$('div:even');
参考代码:
<div>Even</div><!-- 上面的代码将选中这个元素 -->
<div>Odd</div>
<div>Even</div><!-- 上面的代码将选中这个元素 -->
<div>Odd</div>
odd(奇数选择)
和even一样,只不过它选择序号为奇数的元素。
参考代码:
// 选择所有序号为奇数的div
$$('div:odd');
参考代码:
<div>Even</div>
<div>Odd</div><!-- 上面的代码将选中这个元素 -->
<div>Even</div>
<div>Odd</div><!-- 上面的代码将选中这个元素 -->
.getParent();
通过.getParent();方法,你可以得到一个元素的父元素(parent)。
参考代码:
// 选择ID为”child_id“的元素的父元素
$('child_id').getParent();
参考代码:
<div id="parent_id"> <!-- 上面的脚本将返回这个元素-->
<div id="child_id">Even</div>
</div>
代码举例
任何MooTools UI开发都是从选择器开始的。这里是一些非常简单的例子,演示了怎么去使用选择器操作DOM元素。
参考代码:
// 设置所有span的背景颜色为#eee
$$('span').setStyle('background-color', '#eee');
// 设置所有序号为奇数的span的背景色为#eee
$$('span:odd').setStyle('background-color', '#eee');
// 设置ID为body_wrap的元素下的所有CSS类名为.middle_spans的span的背景色为#eee
$('body_wrap').getElements('.middle_spans').setStyle('background-color', '#eee');
参考代码:
<div id="body_wrap"> 
<span>Even</span> 
<span class="middle_spans">Odd</span> 
<span class="middle_spans">Even</span> 
<span>Odd</span> 
</div>

下载zip包并尝试一下
这个zip包中包含了一个简单的html文件、MooTools 1.2核心库、一个外部js文件和上面你所看到的例子。

更多学习……

这并不意味着这是MooTools 1.2的选择器的全部功能列表,这仅仅只是帮助你入门,告诉你MooTools给你提供了什么功能。要学习有关选择器的更多东西,请参考下面的文档:

  • 这里有非常多的有关元素(Element)选择器的文档
  • 顺便也可以看一下选择器(Selectors)

MooTools Blog上有关$$选择器的文章

这是mootools.net上非常好的一篇有关$$选择器和介绍它的变化多端的blog文章。通过这个选择器你可以做多到你无法相信的事情,这篇文章很值得一读。

Slickspeed选择器

这里有别人针对MooTools做的一个实验,测量不同的库在选择元素时到底有多快。这对于它本身来说很cool,不过这些选择器的例子非常有价值。这里所有的选择器特性都可以通过$$方法实现。

W3C选择器

MooTools也可以让你利用伪选择器的力量(就像上面的Slickspeed所证明的)。这里是W3C的一篇关于选择器的文章,一定值得读一遍(如果只有选择器的列表对你有用的话)。我不确定MooTools的$$选择器是不是支持这个页面上的每一个单独选择器,但是至少是绝大部分。欢迎大家告诉我有关这方面的更多消息。

Javascript 相关文章推荐
jquery select动态加载选择(兼容各种浏览器)
Feb 01 Javascript
解析JavaScript中instanceof对于不同的构造器或许都返回true
Dec 03 Javascript
jQuery插件cxSelect多级联动下拉菜单实例解析
Jun 24 Javascript
javascript加载xml 并解析各节点的值(实现方法)
Oct 12 Javascript
jQuery中值得注意的trigger方法浅析
Dec 12 Javascript
原生JS实现九宫格抽奖效果
Apr 01 Javascript
详解vue.js2.0父组件点击触发子组件方法
May 10 Javascript
javascript数据结构之多叉树经典操作示例【创建、添加、遍历、移除等】
Aug 01 Javascript
浅谈vue同一页面中拥有两个表单时,的验证问题
Sep 18 Javascript
对angularJs中自定义指令replace的属性详解
Oct 09 Javascript
vue-router实现嵌套路由的讲解
Jan 19 Javascript
JavaScript 生成唯一ID的几种方式
Feb 19 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
javascript 类定义的4种方法
Sep 12 #Javascript
You might like
关于PHP中Object对象的笔记分享
2011/06/28 PHP
PHP实现的MongoDB数据库操作类分享
2014/05/12 PHP
PHP 闭包详解及实例代码
2016/09/28 PHP
PHP+mysql防止SQL注入的方法小结
2019/04/27 PHP
javascript 自动转到命名锚记
2009/01/10 Javascript
JQuery将文本转化成JSON对象需要注意的问题
2011/05/09 Javascript
EXTJS记事本 当CompositeField遇上RowEditor
2011/07/31 Javascript
js获取select标签的值且兼容IE与firefox
2013/12/30 Javascript
JavaScript数值数组排序示例分享
2014/05/27 Javascript
node.js中的fs.fchownSync方法使用说明
2014/12/16 Javascript
Jquery easyui开启行编辑模式增删改操作
2016/01/14 Javascript
使用jQuery UI库开发Web界面的简单入门指引
2016/04/22 Javascript
JavaScript每天必学之基础知识
2016/09/17 Javascript
JavaScript仿网易选项卡制作代码
2016/10/06 Javascript
JavaScript 中使用 Generator的方法
2017/12/29 Javascript
Vue-cli Eslint在vscode里代码自动格式化的方法
2018/02/23 Javascript
JavaScript常用截取字符串的三种方式用法区别实例解析
2018/05/15 Javascript
vue实现多组关键词对应高亮显示功能
2019/07/25 Javascript
Vue 设置axios请求格式为form-data的操作步骤
2019/10/29 Javascript
微信小程序实现一个简单swiper代码实例
2019/12/30 Javascript
js实现点击选项置顶动画效果
2020/08/25 Javascript
JavaScript 事件代理需要注意的地方
2020/09/08 Javascript
python计算圆周长、面积、球体体积并画出圆
2014/04/08 Python
实例讲解Python的函数闭包使用中应注意的问题
2016/06/20 Python
Python全局变量用法实例分析
2016/07/19 Python
Python获取本机所有网卡ip,掩码和广播地址实例代码
2018/01/22 Python
linux查找当前python解释器的位置方法
2019/02/20 Python
python实现简单图片物体标注工具
2019/03/18 Python
django框架单表操作之增删改实例分析
2019/12/16 Python
python之生成多层json结构的实现
2020/02/27 Python
印度领先的眼镜电子商务网站:Lenskart
2019/12/16 全球购物
实现strstr功能,即在父串中寻找子串首次出现的位置
2016/08/05 面试题
Linux内核的同步机制是什么?主要有哪几种内核锁
2016/07/11 面试题
《云雀的心愿》教学反思
2014/02/25 职场文书
八达岭长城导游词
2015/01/30 职场文书
Python中的协程(Coroutine)操作模块(greenlet、gevent)
2022/05/30 Python