发布于 2016-12-16 22:14:13 | 71 次阅读 | 评论: 0 | 来源: 网友投递
MooTools JavaScript WEB应用框架
MooTools是一个简洁,模块化,面向对象的开源JavaScript web应用框架。
它为web开发者提供了一个跨浏览器js解决方案。在处理js、css、html时候。
它提供了一个比普通js更面向对象的documentAPI。
var BaseClass = new Class({
// 定义一个方法testFunction
// 这个方法弹出一个对话框
testFunction : function(){
alert('This function is defined in BaseClass');
}
});
// 创建一个名叫ImplementingClass的类
var ImplementingClass = new Class({
// 我所做的全部事情就是实现Baseclass
Implements : BaseClass
});
var demo_one = function(){
// 创建一个ImplementingClass实例
var test_class = new ImplementingClass();
// 调用在BaseClass中定义的testFunction
test_class.testFunction();
}
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);
}
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');
}
});
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);
}
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);
}
initialize : function(){
alert('base class');
}
initialize : function(){
// 调用父类的构造函数
this.parent();
alert('extending class');
}
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);
}
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);
}
});
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();
}
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();
}
var demo_eight = function(){
Element.implement({
showStructure : function(){
var structure = '<pre>' + print_r(this, true) + '</pre>';
// 打开一个弹出窗口
newWindow = window.open('','Element Debug','height=600,width=600,scrollbars=yes');
// 把内容写入到弹出窗口中
newWindow.document.write(structure);
}
});
$('demo_eight').showStructure();
}