通过Mootools 1.2来操纵HTML DOM元素


Posted in Javascript onSeptember 15, 2009

我们已经学习过如何来选取DOM元素,怎么创建数组,怎么创建函数,怎么把事件添加到元素,今天我们来深入地学习一下如果操纵HTML元素。通过MooTools 1.2,你可以添加新元素到一个HTML页面中,也可以删除元素,以及改变任何样式或者元素参数,这些都非常容易。
基本方法
.get();
这个工具可以让你获取元素的属性(property)。元素的属性是组成一个HTML元素的各种不同部分,例如src、value、name等等。使用.get();方法非常简单:
参考代码:

// 下面这行将返回id为“id_name”的元素的html标记名(div、a、span……) 
$('id_name').get('tag');

参考代码:

<div id="body_wrap"> 
<span id="id_name">Element</span> <!-- 上面的代码将返回“span” --> 
</div>

你可以使用.get();方法获得更多属性,而不只是html标记名:
id
name
value
href
src
class(如果有多个CSS类名,则将返回全部CSS类名)
text (一个元素的文本内容)
等等…
.set();
.set();方法和.get();方法一样,不过不是获得一个值,而是设置一个值。当和事件联合使用时比较有用,通过这个方法你可以在页面加载之后改变一些属性值。
参考代码:
// 这将设置id为id_name的元素链接地址为“http://www.google.com”
$('id_name').set('href', 'http://www.google.com');

参考代码:

<div id="body_wrap"> 
<!-- 上面的代码将改变链接地址为“http://www.google.com” --> 
<a id="id_name" href="http://www.yahoo.com">Search Engine</a> 
</div>

.erase();
通过.erase();方法,你可以清除一个元素的属性值。它和前面两个方法类似。选取元素,然后选择你要清除的属性。
参考代码:
// 这讲移除id为id_name的元素的href属性
$('id_name').erase('href');

参考代码:

<div id="body_wrap"> 
<!-- 上面的代码将清除链接地址 --> 
<a href="http://www.yahoo.com">Search Engine</a> 
</div>

移动元素
.inject();
要移动页面上一个已经存在的元素,你可以使用.inject();方法。和我们看到的其它方法类似,它用起来也非常简单,可以在你的用户界面上给你更多操控权。要使用.inject();方法,首先要设置一些包含元素变量:
参考代码:

var elementA = $('elemA'); 
var elementB = $('elemB'); 
var elementC = $('elemC');

上面的代码把下面这个HTML分别赋值给了不同的变量,这样用MooTools来操作时会比较简单。
参考代码:
<div id="body_wrap"> 
<div id="elemA">A</div> 
<div id="elemB">B</div> 
<div id="elemC">C</div> 
</div>

现在,要改变这些元素的顺序,我们可以通过四种方式来使用.inject();方法。我们可以把元素注入到:
底部(bottom,默认)
顶部(top)
在某个元素的前面(before)
在某个元素的后面(after)
bottom和top将把这个元素注入到一个选中元素的内部,在元素内最底部或者最顶部。相对地,before和after将把一个元素注入到另外一个元素的顶部或者底部,但是不是注入到元素内部。
因此,让我们把元素顺序改变为A-C-B。由于我们不需要把一个元素注入到另外一个元素的内部,我们可以使用before或者after。
参考代码:
// 下面这句的意思是:把元素C放到元素B之前 
elementC.inject(elementB, 'before'); 
// 下面这句的意思是:把元素B放到元素C之后 
elementB.inject(elementC, 'after');

创建一个新元素
new Element
你可以使用“new Element”构造器来创建一个行的HTML元素。这和写一个正常的HTML元素非常类似,只不过你需要调整一下语法,以便能够在MooTools下正常运行:
参考代码:
// 首先命名一个变量并声明一个“new Element”
// 然后定义元素的类型(div、a、span...)
var newElementVar = new Element('div', {
// 在这里设置元素的所有属性
'id': 'id_name',
'text': 'I am a new div',
'styles': {
// 在这里设置元素的所有样式参数
'width': '200px',
'height': '200px',
'background-color': '#eee',
'float': 'left'
}
});
现在你就有一个元素了,你可以通过我们刚才学的inject();方法把这个元素放在页面上的某个位置。我们从下面这个简单的HTML开始:
参考代码:
<div id="body_wrap">
<div id="content_id">Some div content</div>
</div>
现在,我们把ID为content_id的元素转换为一个变量:
参考代码:
var bodyWrapVar = $('body_wrap');
和我们刚才学的一样,我们可以把我们创建的这个元素注入到当前的HTML中:
参考代码:
// 这句的意思是说:“把newElementVar注入到bodyWrapVar内部,并放置到顶部”
newElementVar.inject(bodyWrapVar , 'top');
这个代码最终可能是这样的:
参考代码:
<div id="body_wrap">
<!-- 这个元素被注入到内部顶部 -->
<div id="id_name">I am a new div</div>
<div id="content_id">Some div content</div>
</div>

示例
为了这个例子,我们来创建一个表单,可以让你添加一个行元素到你的HTML页面。首先,建立一些文本框和按钮。
参考代码:

<div id="body_wrap"> 
ID: <input id="id_input" name="id" /> 
text: <input id="text_input" name="text" /> 
<button id="new_div">创建一个新的div</button> 
</div>

现在,我们来用MooTools写JavaScript来实现让这个HTML表单可以插入一个新的元素到你的页面中。首先,我们先给这个按钮添加一个事件,并写一个函数来包含我们的代码:
参考代码:
var newDiv = function() { 
// 我们将把“添加一个新元素”的代码放在这里 
}; 
window.addEvent('domready', function() { 
$('new_div').addEvent('click', newDiv); 
});

下一件事我们要做的就是指定我们要处理的变量。要使用输入表单中的数据,我们需要使用.get();方法:
参考代码:
var idValue = $('id_input').get('value'); 
var textValue = $('text_input').get('value');

现在,上面代码中的变量idValue和textValue就包含了它们指定的输入表单的值。由于我们需要在用户点击“创建一个新的div”按钮时获得输入框的值,我们需要把上面的代码放在newDiv();这个函数中。如果我们需要在这个函数外面获得这个值,我们需要在页面加载时获得,而不是点击时。
参考代码:
var newDiv = function() { 
var idValue = $('id_input').get('value'); 
var textValue = $('text_input').get('value'); 
}; 
window.addEvent('domready', function() { 
$('new_div').addEvent('click', newDiv); 
});

接下里,我们需要获得我们新元素要插入到的元素:
参考代码:
var newDiv = function() { 
var idValue = $('id_input').get('value'); 
var textValue = $('text_input').get('value'); 
var bodyWrapVar = $('newElementContainer'); 
}; 
window.addEvent('domready', function() { 
$('new_div').addEvent('click', newDiv); 
});

我们已经有了我们的输入表单的值了,现在我们可以创建一个新元素了:
参考代码:
var newDiv = function() { 
var idValue = $('id_input').get('value'); 
var textValue = $('text_input').get('value'); 
var bodyWrapVar = $('newElementContainer'); 
var newElementVar = new Element('div', { 
// 这将设置这个元素的id为idValue的值 
'id': idValue, 
// 这将设置这个元素的文本为textValue的值 
'html': textValue 
}); 
}; 
window.addEvent('domready', function() { 
$('new_div').addEvent('click', newDiv); 
});

剩下我们要做的就是把这个新元素插入到我们的页面中了:
参考代码:
var newDiv = function() { 
var bodyWrapVar = $('newElementContainer'); 
var idValue = $('id_input').get('value'); 
var textValue = $('text_input').get('value'); 
var newElementVar = new Element('div', { 
'id': idValue, 
'text': textValue 
}); 
// 下面这句是说:“把newElementVar插入到bodyWrapVar的内部顶部” 
newElementVar.inject(bodyWrapVar, 'top'); 
}; 
var removeDiv = function() { 
// 这将删除内部的html值(就是div标记类的所有东西) 
$('newElementContainer').erase('html'); 
} 
window.addEvent('domready', function() { 
$('new_div').addEvent('click', newDiv); 
$('remove_div').addEvent('click', removeDiv); 
});

更多学习...

一定要花一些时间看一些MooTools文档中的Elements这一节:

  • Element这一节包含了我们这里讲到的大多数内容,还有很多其它内容
  • Element.style可以给你在元素样式属性上更多的控制权(有些东西我们将在以后的教程中深入讲解)
  • Element.dimentions包含了处理位置、坐标、尺寸大小等东西的工具
Javascript 相关文章推荐
点击广告后才能获得下载地址
Oct 26 Javascript
javascript 图片上传预览-兼容标准
Jun 01 Javascript
几个常用的JavaScript字符串处理函数 - split()、join()、substring()和indexOf()
Jun 02 Javascript
调用innerHTML之后onclick失效问题的解决方法
Jan 28 Javascript
jQuery实现图片左右滚动特效
Apr 20 Javascript
prototype.js常用函数详解
Jun 18 Javascript
jQuery插件学习教程之SlidesJs轮播+Validation验证
Jul 12 Javascript
Javascript 6里的4个新语法
Aug 25 Javascript
javascript实现简易计算器
Feb 01 Javascript
underscore之Collections_动力节点Java学院整理
Jul 10 Javascript
Echarts动态加载多条折线图的实现代码
May 24 Javascript
vue 自定义组件的写法与用法详解
Mar 04 Javascript
Mootools 1.2教程 事件处理
Sep 15 #Javascript
Mootools 1.2教程 函数
Sep 15 #Javascript
Mootools 1.2教程(3) 数组使用简介
Sep 14 #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
You might like
DIY一个适配电脑声卡的动圈话筒放大器
2021/03/02 无线电
dedecms系统常用术语汇总
2007/04/03 PHP
有关PHP中MVC的开发经验分享
2012/05/17 PHP
PHP中将ip地址转成十进制数的两种实用方法
2013/08/15 PHP
php数据库备份还原类分享
2014/03/20 PHP
php生成百度sitemap站点地图类函数实例
2014/10/17 PHP
PHP通过反射动态加载第三方类和获得类源码的实例
2015/11/27 PHP
PHP封装的分页类与简单用法示例
2019/02/25 PHP
Javascript实例教程(19) 使用HoTMetal(2)
2006/12/23 Javascript
用jQuery中的ajax分页实现代码
2011/09/20 Javascript
利用cookie记住背景颜色示例代码
2013/11/04 Javascript
jquery css 设置table的奇偶行背景色示例
2014/06/03 Javascript
nodejs中art-template模板语法的引入及冲突解决方案
2017/11/07 NodeJs
5分钟学会Vue动画效果(小结)
2018/07/21 Javascript
Vuejs2 + Webpack框架里,模拟下载的实例讲解
2018/09/05 Javascript
实例详解vue中的$root和$parent
2019/04/29 Javascript
微信小程序 可搜索的地址选择实现详解
2019/08/28 Javascript
layer iframe 设置关闭按钮的方法
2019/09/12 Javascript
基于JavaScript实现简单抽奖功能代码实例
2020/10/20 Javascript
Python 模拟登陆的两种实现方法
2017/08/10 Python
Python实现PS滤镜功能之波浪特效示例
2018/01/26 Python
Linux下Pycharm、Anaconda环境配置及使用踩坑
2018/12/19 Python
python抓取搜狗微信公众号文章
2019/04/01 Python
Python 根据日志级别打印不同颜色的日志的方法示例
2019/08/08 Python
Python装饰器用法与知识点小结
2020/03/09 Python
编码转换,怎样实现将GB2312编码的字符串转换为ISO-8859-1编码的字符串
2014/01/07 面试题
Java基础类库面试题
2013/09/04 面试题
有针对性的求职自荐信
2013/11/14 职场文书
保证书格式范文
2014/04/28 职场文书
护士求职信范文
2014/05/24 职场文书
优秀毕业生自荐信
2014/06/10 职场文书
公司活动总结怎么写
2014/06/25 职场文书
党委书记群众路线对照检查材料思想汇报
2014/10/04 职场文书
有关浪费资源的建议书
2015/09/14 职场文书
中国古代史学名著《战国策》概述
2019/08/09 职场文书
Python基本的内置数据类型及使用方法
2022/04/13 Python