码迷,mamicode.com
首页 > 移动开发 > 详细

Javascript中call、apply函数浅析

时间:2016-04-03 15:49:24      阅读:106      评论:0      收藏:0      [点我收藏+]

标签:

call/apply函数作用其实就是改变this的取值,有一句话是:谁调用的这个方法那方法里的this就是指谁,而有时我们会需要改变this值,所以call/apply就能派上用场。

下面我写个方法来模拟JQuery中的each方法来加深对call/apply函数的理解

代码如下:

1         function each(arr, callback) {
2             for (var i = 0; i < arr.length; i++) {
3                 callback(arr[i], i, arr[i]);
4             }
5         }
6         each(["zzq", "lihua", "bob"], function (i, val) {
7             console.log(this == val);
8         });

这都知道肯定是打印出来false,因为each里的this是指window,只要我们稍微改造一下

1         function each(arr, callback) {
2             for (var i = 0; i < arr.length; i++) {
3                 //callback.call(arr[i], i, arr[i]); //同下
4                 callback.apply(arr[i], [i, arr[i]]);
5             }
6         }
7         each(["zzq", "lihua", "bob"], function (i, val) {
8             console.log(this == val);
9         });

这时候打印出来就是true了,因为call/apply方法可以改变this的取值,查看JQuery源码的each方法可以发现,实现也是如此

 1     each: function( obj, callback ) {
 2         var length, i = 0;
 3 
 4         if ( isArrayLike( obj ) ) {
 5             length = obj.length;
 6             for ( ; i < length; i++ ) {
 7                 if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {
 8                     break;
 9                 }
10             }
11         } else {
12             for ( i in obj ) {
13                 if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) {
14                     break;
15                 }
16             }
17         }
18 
19         return obj;
20     }

最后总结下:call和apply方法作用是完全一样的,只是apply中参数是用数组传递,在不清楚参数个数时可以使用apply,反之使用call

Javascript中call、apply函数浅析

标签:

原文地址:http://www.cnblogs.com/zuqing/p/5349868.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!