prototype.js的扩展
[prototype.js是由Sam Stephenson写的一个javascript类库。用于建立有高度互动的web2.0特性的富客户端页面。]
1. JavaScript 类的扩展
prototype.js 包中加入功能的一种途径就是扩展已有的JavaScript 类。
2. 对 Object 类的扩展
Object 类的扩展
方法 | 类别 | 参数 | 描述 |
extend(destination,source) | static | destination: 任何对象, source: 任何对象 | 用从 source 到 destination复制所有属性和方法的方式 来提供一种继承机制。 |
extend(object) | instance | 任何对象 | 用从传入的 object 中复制所有属性和方法的方式 来提供一种继承机制。 |
3. 对 Number 类的扩展
Number 类的扩展
方法 | 类别 | 参数 | 描述 |
toColorPart() | instance | (none) | 返回数字的十六进制描述, 当在HTML中转换为RGB颜色组件到HTML中使用的颜色。 |
4.对 Function 类的扩展
对 Function 类的扩展
方法 | 类别 | 参数 | 描述 |
bind(object) | instance | object: 拥有这个方法的对象 | 返回预先绑定在拥有该函数(=方法)的对象上的函数实例, 返回的方法将和原来的方法具有相同的参数。 |
bindAsEventListener(object) | instance | object: 拥有这个方法的对象 | 返回预先绑定在拥有该函数(=方法)的对象上的函数实例, 返回的方法将把当前的事件对象作为它的参数。 |
让我们看看这些扩展的具体例子。
<input type=checkbox id=myChk value=1> Test?<script>
//declaring the class
var CheckboxWatcher = Class.create();
//defining the rest of the class implmentation
CheckboxWatcher.prototype = {
initialize: function(chkBox, message){
this.chkBox = $(chkBox);
this.message = message;
//assigning our method to the event
this.chkBox.onclick = this.showMessage.bindAsEventListener(this);
},
showMessage: function(evt){
alert(this.message + ' (' + evt.type + ')');
}
};
var watcher = new CheckboxWatcher('myChk', 'Changed');
</script>
5. 对 String 类的扩展
String 类的扩展
方法 | 类别 | 参数 | 描述 |
stripTags() | instance | (none) | 返回一个把所有的HTML或XML标记都移除的字符串。 |
escapeHTML() | instance | (none) | 返回一个把所有的HTML标记回避掉的字符串。 |
unescapeHTML() | instance | (none) | 和 escapeHTML()相反。 |
6. 对 document DOM 对象的扩展
document DOM 对象的扩展
方法 | 类别 | 参数 | 描述 |
getElementsByClassName(className) | instance | className: 关联在元素上的CSS类名 | 返回给定的具有相同的CSS类名的所有元素。 |
7. 对 Event 对象的扩展
Event 对象的扩展
属性 | 类型 | 描述 |
KEY_BACKSPACE | Number | 8: 常量,退格(Backspace)键的代码。 |
KEY_TAB | Number | 9: 常量,Tab键的代码。 |
KEY_RETURN | Number | 13: 常量,回车键的代码。 |
KEY_ESC | Number | 27: 常量, Esc键的代码。 |
KEY_LEFT | Number | 37: 常量,左箭头键的代码。 |
KEY_UP | Number | 38: 常量,上箭头键的代码。 |
KEY_RIGHT | Number | 39: 常量,右箭头键的代码。 |
KEY_DOWN | Number | 40: 常量,下箭头键的代码。 |
KEY_DELETE | Number | 46: 常量,删除(Delete)键的代码。 |
observers: | Array | 缓存的观察者的列表,这个对象内部具体实现的一部分。 |
Event 对象的扩展
方法 | 类别 | 参数 | 描述 |
element(event) | static | event: 事件对象 | 返回引发这个事件的元素。 |
isLeftClick(event) | static | event: 事件对象 | 如果鼠标左键单击返回true。 |
pointerX(event) | static | event: 事件对象 | 返回在页面上x坐标。 |
pointerY(event) | static | event: 事件对象 | 返回在页面上y坐标。 |
stop(event) | static | event: 事件对象 | 用这个方法来中止事件的默认行为来使事件的传播停止。 |
findElement(event, tagName) | static | event: 事件对象, tagName: 指定标记的名字 | 向 DOM 树的上位查找,找到第一个给定标记名称的元素, 从这个元素开始触发事件。 |
observe(element, name, observer, useCapture) | static | element: 对象或者对象id, name: 事件名 (如 'click', 'load', etc), observer: 处理这个事件的方法, useCapture: 如果true, 在捕捉到事件的阶段处理事件 那么如果 false在 bubbling 阶段处理。 | 加入一个处理事件的方法。 |
stopObserving(element, name, observer, useCapture) | static | element: 对象或者对象id, name: 事件名 (如 'click', 'load', etc), observer: 处理这个事件的方法, useCapture: 如果true, 在捕捉到事件的阶段处理事件 那么如果 false在 bubbling 阶段处理。 | 删除一个处理实践的方法。 |
_observeAndCache( element, name, observer, useCapture) | static | 私有方法,不用管它。 | |
unloadCache() | static | (none) | 私有方法,不用管它。清除内存中的多有观察着缓存。 |
让我们看看怎样用这个对象加入处理 window 对象的load事件的处理方法。
<script>Event.observe(window, 'load', showMessage, false);
function showMessage(){
alert('Page loaded.');
}
</script>
8. 在 prototype.js中定义的新对象和类
另一个这个程序包帮助你的地方就是提供许多既支持面向对象设计理念又有共通功能的许多对象。
9. PeriodicalExecuter 对象
这个对象提供一定间隔时间上重复调用一个方法的逻辑。
PeriodicalExecuter 对象
方法 | 类别 | 参数 | 描述 |
[ctor](callback, interval) | constructor | callback: 没有参数的方法, interval: 秒数 | 创建这个对象的实例将会重复调用给定的方法。 |
PeriodicalExecuter 对象
属性 | 类型 | 描述 |
callback | Function() | 被调用的方法,该方法不会被传入参数。 |
frequency | Number | 以秒为单位的间隔。 |
currentlyExecuting | Boolean | 表示这个方法是否正在执行。 |
10. Prototype 对象
Prototype 没有太重要的作用,只是声明了该程序包的版本 。
The Prototype object
属性 | 类型 | 描述 |
Version | String | 包的版本。 |
emptyFunction | Function() | 空方法对象。 |
11. Class 对象
在这个程序包中 Class 对象在声明其他的类时候被用到 。用这个对象声明类使得新类支持 initialize() 方法,他起构造方法的作用。
看下面的例子
//declaring the class
var MySampleClass = Class.create();
//defining the rest of the class implmentation
MySampleClass.prototype =
{
initialize: function(message){
this.message = message;
}
showMessage: function(ajaxResponse){
alert(this.message);
}
};
//now, let's instantiate and use one object
var myTalker = new MySampleClass('hi there.');
myTalker.showMessage(); //displays alert
Class 对象
方法 | 类别 | 参数 | 描述 |
create(*) | instance | (any) | 定义新类的构造方法。 |