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

本文详细解析了JavaScript中call和apply函数的使用方法及其应用场景,包括改变函数内部this指向、类初始化、事件绑定等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

<body>
<input type="button" onclick="hhh(this);" value="input.value"/>
</body>
</html>

运行以上的页面就很快明白了.

<wbr></wbr>

call和apply函数可以处理匿名函数

关于类的初始化应用如下:

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

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

<wbr></wbr>

call和apply函数可以赋值函数内容(带匿名参数;但不触发)

关于函数绑定事件应用如下:

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

call和apply函数关于函数绑定参数应用如下:

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

call和apply函数功能是一样的;就是参数格式不同;fun.call(obj, arguments);apply的arguments是数组形式;call则是单数形式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值