js中call,apply,setCapture,releaseCapture的使用


  • 頁面元素拖拽 -- HTML中的setCapture和releaseCapture

setCapture函數的作用就是將後續的mouse事件都發送給這個對象,releaseCapture就是將鼠標事件還回去,由 document、window、object之類的自行來處理,這樣就保證了在拖動的過程中,不會由於經過了其它的元素而受到干擾。另外,還有一個很重 要的事情是,在Win32上,mouse move的事件不是一個連續的,也就是說,並不是我們每次移動1px的鼠標指針,就會發生一個mousemove,windows會週期性檢查mouse 的位置變化來產生mousemove的事件。所以,如果是一個很小的頁面對象,比如一個直徑5px的圓點,如果沒有setCapture和 releaseCapture,那麼在鼠標按住之後,快速的移動鼠標,就有可能鼠標移動走了,但是小圓點還在原地,就是因爲下一次的mousemove事 件已經不再發給這個圓點對象了。

  • 關於javascript中call和apply函數的應用
我們經常在javascipt中的面向對象應用中遇到call和apply函數;有時會被搞糊塗。其實它們可以改變函數或對象中的this保留字的值;this保留字的默認值就是這個類本身。舉例說明:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<script language="javascript">
test = {
 value : 'default',
 exec  : function(){
  alert(this.value);
 }
}
function hhh(obj){
  test.exec();
  test.exec.apply(obj);
}
</script>
</head>

<body>
<input type="button" οnclick="hhh(this);" value="test"/>
</body>
</html>

運行以上的頁面就很快明白了.

 

call和apply函數可以處理匿名函數

關於類的初始化應用如下:

Person = function(){
 this.Init.apply(this, arguments);
};
Person.prototype = {
 first : null,
 last : null,
 Init : function(first, last){
    this.first = first;
    this.last = last; 
 },
 fullName : function(){
    return this.first + ' ' + this.last; 
 },
 fullNameReversed : function(){
    return this.last + ', ' + this.first;  
 }
};

var s = new Person2('creese', 'yang');
alert(s.fullName());
alert(s.fullNameReversed());

 

call和apply函數可以賦值函數內容(帶匿名參數;但不觸發)

關於函數綁定事件應用如下:

Function.prototype.BindForEvent = function() {
  var __m = this, object = arguments[0], args = new Array();
  for(var i = 1; i < arguments.length; i++){
  args.push(arguments[i]);
 }
  return function(event) {
    return __m.apply(object, [( event || window.event)].concat(args));
  }
}

call和apply函數關於函數綁定參數應用如下:

Function.prototype.Bind = function() {
  var __m = this, object = arguments[0], args = new Array();
  for(var i = 1; i < arguments.length; i++){
  args.push(arguments[i]);
 }
  return function() {
    return __m.apply(object, args);
  }
}

call和apply函數功能是一樣的;就是參數格式不同;fun.call(obj, arguments);apply的arguments是數組形式;call則是單數形式。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章