Mootools 1.2教程 类(一)


Posted in Javascript onSeptember 15, 2009

简单地讲,一个类就是一个容器,这个容器包含了一些变量集合和操作这些变量的函数,以便实现特定的功能。在一个内容牵涉较多的项目中,类会显得难以置信的有用。
变量
在前面一系列的课程中,我们已经学习过了Hash对象中键值对(key/value pair)的使用方式,因此,下面的这个例子中创建了一个类,它只包含了一些变量,你看起来可能会觉得非常的熟悉:
参考代码:

// 创建一个名为class_one的类 
// 包含两个内部变量 
var Class_one = new Class({ 
variable_one : "I'm First", 
variable_two : "I'm Second" 
});

类似地,你可以通过类似访问hash中的变量的方式来访问其中的变量,注意一下,在下面的代码中,我们创建了一个我们在上面定义的Class_one类的实例。
参考代码:
var run_demo_one = function(){ 
// 创建类Class_one的一个实例,名称为demo_1 
var demo_1 = new Class_one(); 
// 显示demo_1中的变量 
alert( demo_1.variable_one ); 
alert( demo_1.variable_two ); 
}

方法/函数
方法是指一个指定的类中的函数(通俗地说就是一个类中的函数就叫做方法,换了个叫法而已)。这些方法必须通过这个类的实例来调用,而类本身不能调用它们。你可以像定义一个变量来定义一个方法,不同的是你需要给它指定一个静态的值,给它指定一个匿名函数:
参考代码:
var Class_two = new Class({ 
variable_one : "I'm First", 
variable_two : "I'm Second", 
function_one : function(){ 
alert('First Value : ' + this.variable_one); 
}, 
function_two : function(){ 
alert('Second Value : ' + this.variable_two); 
} 
});

注意一下上面例子中的关键字this的使用。由于在上面的方法中操作的变量都是类内部的变量,因此你需要通过使用关键字this来访问这些变量,否则你将只能得到一个undefined值。
参考代码:
// 正确 
working_method : function(){ 
alert('First Value : ' + this.variable_one); 
}, 
// 错误 
broken_method : function(){ 
alert('Second Value : ' + variable_two); 
}

调用新创建的类中的方法就像访问那些类的变量一样。
参考代码:
var run_demo_2 = function(){ 
// 实例化一个类class_two 
var demo_2 = new Class_two(); 
// 调用function_one 
demo_2.function_one(); 
// 调用function_two 
demo_2.function_two(); 
}

initialize方法
类对象中的initialize选项可以让你来对类进行一些初始化操作,也可以让你来处理一些可供用户设置的选项和变量。(Fdream注:实际上这个就相当于类的初始化方法。)你可以像定义方法一样来定义它:
参考代码:
var Myclass = new Class({ 
// 定义一个包含一个参数的初始化方法 
initialize : function(user_input){ 
// 创建一个属于这个类的变量 
// 并给它赋值 
// 值为用户传进来的值 
this.value = user_input; 
} 
})

你也可以通过这个初始化来改变其他的选项或者行为:
参考代码:
var Myclass = new Class({ 
initialize : function(true_false_value){ 
if (true_false_value){ 
this.message = "Everything this message says is true"; 
} 
else { 
this.message = "Everything this message says is false"; 
} 
} 
}) 
// 这将设置myClass实例的message属性为下面的字符串 
// "Everything this message says is true" 
var myclass_instance = new Myclass(true); 
// 这将设置myClass实例的message属性为下面的字符串 
// "Everything this message says is false" 
var myclass_instance = new Myclass(false);

所有的这一切工作都不需要声明任何其他变量或者方法。只需要记住每个键值对后面的逗号就行了。真的是非常容易漏掉一个逗号,然后花费大量的时间来追踪这些不存在的漏洞。
参考代码:
var Class_three = new Class({ 
// 当类创建的时候就会执行这个类 
initialize : function(one, two, true_false_option){ 
this.variable_one = one; 
this.variable_two = two; 
if (true_false_option){ 
this.boolean_option = "True Selected"; 
} 
else { 
this.boolean_option = "False Selected"; 
} 
}, 
// 定义一些方法 
function_one : function(){ 
alert('First Value : ' + this.variable_one); 
}, 
function_two : function(){ 
alert('Second Value : ' + this.variable_two); 
} 
}); 
var run_demo_3 = function(){ 
var demo_3 = new Class_three("First Argument", "Second Argument"); 
demo_3.function_one(); 
demo_3.function_two(); 
}

实现选项功能
当创建类的时候,给类中的一些变量设置一些默认值会非常有用,如果用户没有提供初始输入的话。你可以手动地在初始化方法中设置这些变量,检查每一个输入来看用户是不是提供了相应的值,然后替换相应的默认值。或者,你也可以使用MooTools中Class.extras提供的Options类来实现。
给你的类增加一个选项功能非常简单,就像给类添加一个其他的键值对一样:
参考代码:
var Myclass = new Class({ 
Implements: Options 
})

首先不要太着急实现选项的细节问题,我们会在后面的教程中更深入的学习。现在,我们已经拥有一个有选项功能的类了,我们还需要做的就是定义一些默认的选项。和其他的所有东西一样,只需要添加一些需要初始化的键值对就可以了。与定义单个值不一样的是,你需要像下面这样定义一组键值对集合:
参考代码:
var Myclass = new Class({ 
Implements: Options, 
options: { 
option_one : "First Option", 
option_two : "Second Option" 
} 
})

现在我们就有了这些默认的集合,我们还需要提供一个方式来供用户在初始化这个类的时候覆盖这些默认值。你所要做的工作就是在你的初始化函数中增加一行新的代码,而Options类会完成其余的工作:
参考代码:
var Myclass = new Class({ 
Implements: Options, 
options: { 
option_one : "First Default Option", 
option_two : "Second Default Option" 
} 
initialize: function(options){ 
this.setOptions(options); 
} 
})

一旦这个完成以后,你就可以通过传递一组键值对来覆盖任何默认选项:
参考代码:
// 覆盖所有的默认选项 
var class_instance = new Myclass({ 
options_one : "Override First Option", 
options_two : "Override Second Option" 
}); 
// 覆盖其中的一个默认选项 
var class_instance = new Myclass({ 
options_two : "Override Second Option" 
})

注意一下初始化函数中的setOptions方法。这是Options类中提供的一个方法,可以让你在实例化一个类的时候设置选项。
参考代码:
var class_instance = new Myclass(); 
// 设置第一个选项 
class_instance.setOptions({options_one : "Override First Option"});

一旦设置了选项,你就可以通过变量options来访问它们。
参考代码:
var class_instance = new Myclass(); 
// 取得第一个选项的值 
var class_option = class_instance.options.options_one; 
// 变量class_option现在的值就为"First Default Option"了

如果你想在类的内部访问这个选项,请使用this语句:
参考代码:
var Myclass = new Class({ 
Implements: Options, 
options: { 
option_one : "First Default Option", 
option_two : "Second Default Option" 
} 
test : function(){ 
// 注意我们使用this关键字来 
// 引用这个类 
alert(this.option_two); 
} 
}); 
var class_instance = new Myclass(); 
// 将弹出一个对话框,显示"Second Default Option" 
class_instance.test();

把这些东西组合成一个类,看起来就是这样的:
参考代码:
var Class_four = new Class({ 
Implements: Options, 
options: { 
option_one : "Default Value For First Option", 
option_two : "Default Value For Second Option", 
}, 
initialize: function(options){ 
this.setOptions(options); 
}, 
show_options : function(){ 
alert(this.options.option_one + "\n" + this.options.option_two); 
}, 
}); 
var run_demo_4 = function ){ 
var demo_4 = new Class_four({ 
option_one : "New Value" 
}); 
demo_4.show_options(); 
} 
var run_demo_5 = function(){ 
var demo_5 = new Class_four(); 
demo_5.show_options(); 
demo_5.setOptions({option_two : "New Value"}); 
demo_5.show_options(); 
} 
// 创建一个类class_four的实例 
// 并指定一个名叫new_option的新选项 
var run_demo_6 = function(){ 
var demo_6 = new Class_four({new_option : "This is a new option"}); 
demo_6.show_options(); 
}

代码及示例
熟悉PHP的人可能认识下面示例中的show_options方法中的print_r()函数:
参考代码:
show_options : function(){ 
alert(print_r(this.options, true)); 
}

这不是一个javascript的原生方法,只不过是从PHP2JS项目中Kevin van Zonneveld的一小段代码而已。对于那些不熟悉PHP的人,这个print_r()方法就给你了一个数组中键值对格式化后的字符串。在调试脚本的过程中,这是一个极其有用的debug工具,这个函数在后面提供的下载包中有详细的代码,我强烈推荐使用它来测试和研究。
参考代码:
var Class_five = new Class({ 
// 我们使用了选项 
Implements: Options, 
// 设置我们的默认选项 
options : { 
option_one : "DEFAULT_1", 
option_two : "DEFAULT_2", 
}, 
// 设置我们的初始化函数 
// 通过setOptions方法来设置选项 
initialize : function(options){ 
this.setOptions(options); 
}, 
// 用来打印选项数组信息的方法 
show_options : function(){ 
alert(print_r(this.options, true)); 
}, 
// 通过setOptions方法来交换两个选项的值 
swap_options : function(){ 
this.setOptions({ 
option_one : this.options.option_two, 
option_two : this.options.option_one 
}) 
} 
}); 
function demo_7(){ 
var demo_7 = new Class_five(); 
demo_7.show_options(); 
demo_7.setOptions({option_one : "New Value"}); 
demo_7.swap_options(); 
demo_7.show_options(); 
}

更多学习

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

    MooTools Class文档MooTools Class.extra文档print_r()参考
Javascript 相关文章推荐
javascritp实现input输入框相关限制用法
Jun 29 Javascript
关于extjs treepanel复选框选中父节点与子节点的问题
Apr 02 Javascript
JavaScript对象的property属性详解
Apr 01 Javascript
js动态移动滚动条至底部示例代码
Apr 24 Javascript
js简单实现竖向tab选项卡的方法
May 04 Javascript
jQuery实现的多级下拉菜单效果代码
Aug 24 Javascript
jQuery html表格排序插件tablesorter使用方法详解
Feb 10 Javascript
详解webpack2+React 实例demo
Sep 11 Javascript
vue-cli脚手架config目录下index.js配置文件的方法
Mar 13 Javascript
JavaScript实现的DOM绘制柱状图效果示例
Aug 08 Javascript
VUE+node(express)实现前后端分离
Oct 13 Javascript
js实现html滑动图片拼图验证
Jun 24 Javascript
Mootools 1.2 手风琴(Accordion)教程
Sep 15 #Javascript
Mootools 1.2教程 排序类和方法简介
Sep 15 #Javascript
Mootools 1.2教程 滚动条(Slider)
Sep 15 #Javascript
Mootools 1.2教程 定时器和哈希简介
Sep 15 #Javascript
Mootools 1.2教程 正则表达式
Sep 15 #Javascript
MooTools 1.2中的Drag.Move来实现拖放
Sep 15 #Javascript
Mootools 1.2教程 Fx.Morph、Fx选项和Fx事件
Sep 15 #Javascript
You might like
《魔兽争霸3:重制版》翻车了?你想要的我们都没有
2019/11/07 魔兽争霸
php中json_decode()和json_encode()的使用方法
2012/06/04 PHP
PHP实现提取多维数组指定一列的方法总结
2019/12/04 PHP
在b/s开发中经常用到的javaScript技术
2006/08/23 Javascript
Javascript实例教程(19) 使用HoTMetal(7)
2006/12/23 Javascript
jquery获取ASP.NET服务器端控件dropdownlist和radiobuttonlist生成客户端HTML标签后的value和text值
2010/06/28 Javascript
关于scrollLeft,scrollTop的浏览器兼容性测试
2013/03/19 Javascript
简单易用的倒计时js代码
2014/08/04 Javascript
Windows8下搭建Node.js开发环境教程
2014/09/03 Javascript
jQuery中innerHeight()方法用法实例
2015/01/19 Javascript
Jquery 实现checkbox全选方法
2015/01/28 Javascript
提交按钮的name='submit'引起的js失效问题及原因
2015/02/25 Javascript
jQuery Validate插件实现表单验证
2016/08/19 Javascript
详解vue前后台数据交互vue-resource文档
2017/07/19 Javascript
浅析Vue.js 中的条件渲染指令
2018/11/19 Javascript
js中对象和面向对象与Json介绍
2019/01/21 Javascript
js中比较两个对象是否相同的方法示例
2019/09/02 Javascript
Vue.js数字输入框组件使用方法详解
2019/10/19 Javascript
vue父子组件间引用之$parent、$children
2020/05/20 Javascript
基于postman获取动态数据过程详解
2020/09/08 Javascript
[30:55]完美世界DOTA2联赛PWL S2 Magma vs LBZS 第二场 11.18
2020/11/18 DOTA
[05:23]DOTA2-DPC中国联赛2月1日Recap集锦
2021/03/11 DOTA
python实现的AES双向对称加密解密与用法分析
2017/05/02 Python
在python中将字符串转为json对象并取值的方法
2018/12/31 Python
python处理“
2019/06/10 Python
Python 中使用 PyMySQL模块操作数据库的方法
2019/11/10 Python
Python Opencv 通过轨迹(跟踪)栏实现更改整张图像的背景颜色
2020/03/09 Python
使用Python-OpenCV消除图像中孤立的小区域操作
2020/07/05 Python
利用纯CSS3实现tab选项卡切换示例代码
2016/09/21 HTML / CSS
沙特阿拉伯家用电器和电子产品购物网站:Sheta and Saif
2020/04/03 全球购物
爽歪歪广告词
2014/03/20 职场文书
红领巾心向党演讲稿
2014/09/10 职场文书
捐助感谢信
2015/01/22 职场文书
活动经费申请报告
2015/05/15 职场文书
大学生十八大感想
2015/08/11 职场文书
组织委员竞选稿
2015/11/21 职场文书