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)  定义新类的构造方法。 

 

你可能感兴趣的:(prototype)