热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Mootools1.2教程(21)——类(二)_Mootools

在今天的教程中,我们将主要学习一下MooTools中类的实现和继承(扩展)。
Fdream注:原文好像少了一部分,因此我自作主张地补充了下面这一段及BaseClass的代码。
在今天的教程中,我们将主要学习一下MooTools中类的实现和继承(扩展)。通过实现和继承,我们可以在子类中使用父类的方法,而不需要再重新声明和实现相同的方法。MooTools中的Class类可以帮助我们轻松地做到这一点。首先,我们定一个基类(base class)。
参考代码:

代码如下:


var BaseClass = new Class({
// 定义一个方法testFunction
// 这个方法弹出一个对话框
testFunction : function(){
alert('This function is defined in BaseClass');
}
});


现在,我们已经有了一个基类(base class),我们可以通过创建一个新类来实现它从而使用它的全部功能。注意,在下面的例子中,我们的新类没有做任何事情,而只是实现了基类BaseClass。
参考代码:

代码如下:


// 创建一个名叫ImplementingClass的类
var ImplementingClass = new Class({
// 我所做的全部事情就是实现Baseclass
Implements : BaseClass
});


现在,我们就可以创建一个ImplementingClass的实例,并使用在BaseClass中定义的方法。
参考代码:

代码如下:


var demo_One= function(){
// 创建一个ImplementingClass实例
var test_class = new ImplementingClass();
// 调用在BaseClass中定义的testFunction
test_class.testFunction();
}


demo_one()
你也可以对基类中的变量和初始化函数(构造函数)做同样的事情。如果你在实施类(实现基类的类)中声明了的话,每个你在基类中定义的东西就将被转移到实施类中。
注意:从现在开始,我们下面所有的示例中将全部使用下面这个版本的BaseClass。
参考代码:

代码如下:


var BaseClass = new Class({
// 把参数赋值给这个类中的inputVariable变量
initialize: function(input){
this.inputVariable = input;
},
// 显示变量inputVariable的值
testFunction : function(){
alert('BaseClass.testFunction() : ' + this.inputVariable);
},
// 为这个类的所有实例定义一个内部变量
definedVariable : "Defined in BaseClass",
});
var ImplementingClass = new Class({
// 重复一遍:
// 这里我们做的全部事情就只是实现BaseClass
Implements : BaseClass
});


下面的示例表明:初始化程序、函数调用和变量都可以被访问到,就像它们是属于这个实施类的。
参考代码:

代码如下:


var demo_two = function(){
// 创建一个ImplementingClass实例
var test_class = new ImplementingClass('this is the input value');
// 调用testFunction()(在BaseClass中定义的)
test_class.testFunction();
// 显示变量definedVariable的值
alert('test_class.testVariable : ' + test_class.definedVariable);
}


demo_two()
一旦你实现了一个类,你可以添加任何你想要的功能到你的实施类定义中。
参考代码:

代码如下:


var ImplementingClass = new Class({
Implements : BaseClass,
// 下面的这些功能都在BaseClass中定义了
definedVariable : "Defined in ImplementingClass",
testFunction : function(){
alert('This function is also defined in BaseClass');
},
// 下面的这些都没有在BaseClass中定义
anotherDefinedVariable : "Also Defined in ImplementingClass",
anotherTestFunction : function(){
alert('This function is defined in ImplementingClass');
}
});


请注意,我们在实施类中重新定义了testFunction和definedVariable,就像我们添加新的函数和变量一样。特别需要注意的是:如果你想在实施类中定义一个已经在基类中定义了的函数或者变量,基类中的定义将会取代实施类中的定义。如果不明白,看看下面的例子就知道了。
参考代码:

代码如下:


var demo_three = function(){
// 创建一个ImplementingClass实例
var test_class = new ImplementingClass('this is the input value');
// (执行BaseClass中定义的方法)
test_class.testFunction();
// 显示变量definedVariable的值(BaseClass中定义的值)
alert('test_class.testVariable : ' + test_class.definedVariable);
// (ImplementingClass中定义的方法)
test_class.anotherTestFunction();
// 显示变量anotherDefinedVariable的值(ImplementingClass中定义的值)
alert('test_class.anotherDefinedVariable : ' + test_class.anotherDefinedVariable);
}


demo_three()
Extends(扩展)
如果你想要覆盖基类中定义的方法和变量,你可以使用Extends。简单地把上面代码中的“Implements”替换成“Extends”就可以了。
参考代码:

代码如下:


var ExtendingClass = new Class({
// 注意这里用Extends替代了Implements
Extends : BaseClass,
// 下面的这些都在BaseClass中定义了
// 但是我们用extend替代了implements
// 这将覆盖在BaseClass中的定义
definedVariable : "Defined in ImplementingClass",
testFunction : function(){
alert('This function is also defined in BaseClass');
}
});
var demo_four = function(){
// 创建一个ImplementingClass实例
var test_class = new ExtendingClass('this is the input value');
// 调用testFunction()(同时在BaseClass和ExtendingClass中都有定义)
test_class.testFunction();
// 显示变量definedVariable的值(同时在BaseClass和ExtendingClass中都有定义)
alert('test_class.definedVariable : ' + test_class.definedVariable);
}


demo_four()
使用extends的另外一个有用的功能是,它提供了一个功能:在覆盖基类的初始化方法时,你仍然可以调用基类中的初始化方法。因此,如果你在基类中定义了一个这样的初始化方法:
参考代码:

代码如下:


initialize : function(){
alert('base class');
}


然后,在扩展类中定义了下面这样一个初始化方法,那么将会弹出两个提示分别显示“base class”和“extending class”。
参考代码:

代码如下:


initialize : function(){
// 调用父类的构造函数
this.parent();
alert('extending class');
}


如果父类的初始化函数需要参数,请一定要确保在这个初始化函数中又相同的输入参数并传递给父类的构造函数。在下面的示例中,请注意我们没有给input指定任何值——我们只是把它传递给了父类的构造函数,它会自动管理好的。
参考代码:

代码如下:


var ExtendingClass = new Class({
// 重复一遍:我们在使用扩展方法,而不是实现
Extends : BaseClass,
initialize: function(input){
// 通过调用this.parent来执行父类的初始化方法
this.parent(input);
// 这样我们可以在初始化方法中做一些其他的事情
// 而不用完全覆盖父类的方法
this.otherVariable = "Original Input Was : " + input;
}
});
var demo_five = function(){
// 创建我们的扩展类实例
var test_class = new ExtendingClass('this is the input value');
// 调用testFunction
test_class.testFunction();
// 显示变量otherVariable的值
alert("test_class.otherVariable : " + test_class.otherVariable);
}


demo_five()
.implement()方法
你不仅可以使用implements和extends来扩展你的类定义,你还可以使用它们原有的类来一次添加一个功能。在下面的这个示例中,我们将使用一个简单的计算器类(calculator),定义这个类的时候,我们只给了它一个对两个数字做加法运算和一个做减法运算的功能。
参考代码:

代码如下:


var Calculator = new Class({
// 在初始化的时候指定两个数字
initialize: function(first_number, second_number){
this.first = first_number;
this.secOnd= second_number;
},
// 把两个数字相加
// 并返回结果
add : function(){
result = this.first + this.second;
alert(result);
},
// 把两个数字相减
// 并返回结果
subtract : function(){
result = this.first - this.second;
alert(result);
}
});


如果你只是要对数字做加法或者减法运算,这一切看起来都很好,但是,如果你要对它们做乘法怎么办呢?使用.implement();方法,我们可以给这个类添加一个功能,就像我们已经创建了另外一个以Calculator类为基类的类一样。
参考代码:

代码如下:


var demo_six = function(){
// 为Calculator类实现
// 实现一个方法
Calculator.implement({
// 把两个数字相乘
// 并返回结果
multiply : function(){
result = this.first * this.second;
alert(result);
}
});
// 建立一个Calculator类实例
var myCalculator = new Calculator(100, 50);
// 调用multiply方法
myCalculator.multiply();
}


demo_six()
在类教程的第一部分中,我们使用了print_r这个函数来调试Javascript。使用implement方法,我们可以让它非常轻松地打印出出一个类中的变量值,只要在Calculator中实现这个方法就行了。
参考代码:

代码如下:


var demo_seven = function(){
// 为Calculator类实现一个方法
// 用来打印这个类里面的内容
Calculator.implement({
show_class : function(){
alert(print_r(this, true));
}
});
// 建立一个Calculator类实例
var myCalculator = new Calculator(100, 50);
// 显示类的详细信息
myCalculator.show_class();
}


demo_seven()
代码示例
虽然很简洁,不过这对于相对比较简单的计算器这个类来说不是一个特别有用的功能。但是,由于MooTools里面的大多数对象都是用相同的方式建立的类,因此我们可以用这种方式来扩充MooTools的类,提供更多功能。下面的例子实现了一个功能,它可以显示任何你想看的HTML的内容结构。这个功能现在就被自动地添加到了任何与你交互的HTML元素,因此你可以给你的元素添加一个showStructure元素的完整描述。
参考代码:

代码如下:


var demo_eight = function(){
Element.implement({
showStructure : function(){
var structure = '

' + print_r(this, true) + '
';
// 打开一个弹出窗口
newWindow = window.open('','Element Debug','height=600,width=600,scrollbars=yes');
// 把内容写入到弹出窗口中
newWindow.document.write(structure);
}
});
$('demo_eight').showStructure();
}


注意:要让这个示例能正确显示,你需要先允许该页面弹出窗口。

更多学习

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

MooTools Class文档

一些非常好的关于更好地利用MooTools类的讨论

推荐阅读
  • 表单提交前的最后验证:通常在表单提交前,我们必须确认用户是否都把必须填选的做了,如果没有,就不能被提交到服务器,这里我们用到表单的formname.submit()看演示,其实这个对于我们修炼道 ... [详细]
  • Itwasworkingcorrectly,butyesterdayitstartedgiving401.IhavetriedwithGooglecontactsAPI ... [详细]
  • Iwouldliketobeabletohaveasidebarthatcanbetoggledinandoutonabuttonpress.However ... [详细]
  • 但有时候,需要当某事件触发时,我们先做一些操作,然后再跳转,这时,就要用JAVASCRIPT来实现这一跳转功能。下面是具体的做法:一:跳转到新页面,并且是在新窗口中打开时:复制代码代码如下:fu ... [详细]
  • JavaScript在常人看来都是门出不了厅堂的小语言,仅管它没有明星语言的闪耀,但至少网页的闪耀还是需要它的,同时它是一门很实用的语言,本人平时就喜欢拿它来写点实用工具或应用,本文演示用JavaSc ... [详细]
  • JavaScript概述1.JavaScript定义JavaScript是Netscape公司开发的一种基于对象和事件驱动的脚本语言。它是弱类型语言,只能由浏览器解释执行。其中:脚本语言:解释运行( ... [详细]
  • JavaScript实现在页面间传值的方法-本文实例讲述了JavaScript实现在页面间传值的方法。分享给大家供大家参考。具体如下:问题如下:在a.html页面中,的 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • Nginx使用(server参数配置)
    本文介绍了Nginx的使用,重点讲解了server参数配置,包括端口号、主机名、根目录等内容。同时,还介绍了Nginx的反向代理功能。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 电销机器人作为一种人工智能技术载体,可以帮助企业提升电销效率并节省人工成本。然而,电销机器人市场缺乏统一的市场准入标准,产品品质良莠不齐。创业者在代理或购买电销机器人时应注意谨防用录音冒充真人语音通话以及宣传技术与实际效果不符的情况。选择电销机器人时需要考察公司资质和产品品质,尤其要关注语音识别率。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 如何去除Win7快捷方式的箭头
    本文介绍了如何去除Win7快捷方式的箭头的方法,通过生成一个透明的ico图标并将其命名为Empty.ico,将图标复制到windows目录下,并导入注册表,即可去除箭头。这样做可以改善默认快捷方式的外观,提升桌面整洁度。 ... [详细]
  • 浅析javascript异步执行函数导致的变量变化问题解决思路-浅析javascript异步执行函数导致的变量变化问题解决思路for(vari0;i ... [详细]
author-avatar
比熊--悉尼
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有