免费教程_免费网赚教程_破解版软件-寂涯网络学习基地

当前位置: 主页 > 网站相关 > 网站编程 > 关于js中call和apply函数的应用

关于js中call和apply函数的应用

时间:2012-01-20 20:07来源:未知 整理:寂涯网络 点击:

我们经常在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 : 'self.value',
 exec  : function(){
  alert(this.value);
 }
}
function hhh(obj){
  test.exec();
  test.exec.apply(obj);
}
</script>
</head>

<body>
<input type="button" onclick="hhh(this);" value="input.value"/>
</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);
  }
}

本页地址 http://www.jybase.net/wangzhanbiancheng/20120120756.html

百度搜索更多

谷歌搜索更多

顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------

评价:
昵称: 验证码:点击我更换图片
推荐内容
赞助商
赞助商


关于本站免责声明视频更新google百度地图视频地图RRS订阅

如有什么问题请在本站留言,或发邮件到 hxt167#foxmail.com