浅谈javascript中call()、apply()、bind()的用法


Posted in Javascript onApril 20, 2015

call(thisObj,arg1,arg2...)、apply(thisObj,[obj1,obj2...])这二个方法是每个函数都包含的非继承的方法

call(thisobj[, args])和apply(thisobj[, args])

作用都是一样的,简单来说就是改变当前使用该方法的对象中的this指向,指向调用方法中的thisObj对象二者的区别(第一个参数是相同的)就是call方法中传入的参数是是一个个列举出来的,而apply方法中的参数二是一个数组

还是举例说明比较直观:

window.color='red';
var o={color:"blue"};
function sayColor(){
alert(this.color);
};
sayColor(); //red(全局函数,this是window)
sayColor.call(this);//red(调用call方法,指定对象是this,这里的this是window,没什么意义)
sayColor.call(window);//red(调用call方法,指定对象是window,没什么意义)
sayColor.call(o); //blue (调用call方法,指定对象是o,所以this指代对象o,这里由原来的window指向了o)
sayColor.apply(o);//blue (调用call方法,指定对象是o,所以this指代对象o,这里由原来的window指向了o)

ECMAScript5中的bind()方法和前二种方法相似,bind()这个方法会创建一个函数的实例,这个实例的this值会被绑定到传递给bind()函数的值

例子:

function a(y){
return this.x+y;
};
var o={x:1};
var g=a.bind(o);
g(2);//3

从例子中可以看出函数a绑定到对象o上了,并且返回了新的函数g,调用g时,a函数会当作对象o的方法来调用 
bind()这个方法是将函数绑定到某个对象上,并且返回一个新的函数,这个新函数中传入的参数都将传入被绑定的函数上。

下面来看看他们的区别

在JS中,这三者都是用来改变函数的this对象的指向的,他们有什么样的区别呢。
在说区别之前还是先总结一下三者的相似之处:
1、都是用来改变函数的this对象的指向的。
2、第一个参数都是this要指向的对象。
3、都可以利用后续参数传参。
那么他们的区别在哪里的,先看一个例子。
                var xw = {
                        name : "小王",
                        gender : "男",
                        age : 24,
                        say : function() {
                                alert(this.name + " , " + this.gender + " ,今年" + this.age);                               
                        }
                }
                var xh = {
                        name : "小红",
                        gender : "女",
                        age : 18
                }
                xw.say();
本身没什么好说的,显示的肯定是小王 , 男 , 今年24。

那么如何用xw的say方法来显示xh的数据呢。

对于call可以这样:

xw.say.call(xh);

对于apply可以这样:

xw.say.apply(xh);

而对于bind来说需要这样:

xw.say.bind(xh)();

如果直接写xw.say.bind(xh)是不会有任何结果的,看到区别了吗?call和apply都是对函数的直接调用,而bind方法返回的仍然是一个函数,因此后面还需要()来进行调用才可以。
那么call和apply有什么区别呢?我们把例子稍微改写一下。

var xw = {
            name : "小王",
            gender : "男",
            age : 24,
            say : function(school,grade) {
                alert(this.name + " , " + this.gender + " ,今年" + this.age + " ,在" + school + "上" + grade);                
            }
        }
        var xh = {
            name : "小红",
            gender : "女",
            age : 18
        }

可以看到say方法多了两个参数,我们通过call/apply的参数进行传参。
对于call来说是这样的

xw.say.call(xh,"实验小学","六年级");      

而对于apply来说是这样的

xw.say.apply(xh,["实验小学","六年级郑州牛皮癣医院"]);

看到区别了吗,call后面的参数与say方法中是一一对应的,而apply的第二个参数是一个数组,数组中的元素是和say方法中一一对应的,这就是两者最大的区别。
那么bind怎么传参呢?它可以像call那样传参。

xw.say.bind(xh,"实验小学","六年级")();

但是由于bind返回的仍然是一个函数,所以我们还可以在调用的时候再进行传参。

xw.say.bind(xh)("实验小学","六年级");

以上所述就是本文的全部内容了,希望大家能够喜欢、

Javascript 相关文章推荐
Js 刷新框架页的代码
Apr 13 Javascript
让你的CSS像Jquery一样做筛选的实现方法
Jul 10 Javascript
原生的html元素选择器类似jquery选择器
Oct 15 Javascript
jQuery寻找n以内完全数的方法
Jun 24 Javascript
JS建造者模式基本用法实例分析
Jun 30 Javascript
javascript实现的猜数小游戏完整实例代码
May 10 Javascript
详解从零搭建 vue2 vue-router2 webpack3 工程
Nov 22 Javascript
Angular 项目实现国际化的方法
Jan 08 Javascript
Vue封装Swiper实现图片轮播效果
Feb 06 Javascript
vue组件实现弹出框点击显示隐藏效果
Oct 26 Javascript
vue服务端渲染缓存应用详解
Sep 12 Javascript
微信小程序背景音乐开发详解
Dec 12 Javascript
javascript中callee与caller的区别分析
Apr 20 #Javascript
javascript正则表达式中的replace方法详解
Apr 20 #Javascript
javascript正则表达式基础知识入门
Apr 20 #Javascript
javascript实现表单提交后,提交按钮不可用的方法
Apr 18 #Javascript
Javascript实现颜色rgb与16进制转换的方法
Apr 18 #Javascript
JS解析XML文件和XML字符串详解
Apr 17 #Javascript
JS设置cookie、读取cookie、删除cookie
Apr 17 #Javascript
You might like
PHP中include()与require()的区别说明
2010/03/10 PHP
PHP数组操作简单案例分析
2016/10/15 PHP
PHP二维数组去重实例分析
2016/11/18 PHP
PHP使用微信开发模式实现搜索已发送图文及匹配关键字回复的方法
2017/09/13 PHP
PHP实现通过strace定位故障原因的方法
2018/04/29 PHP
Laravel6.0.4中将添加计划任务事件的方法步骤
2019/10/15 PHP
iframe异步加载实现点击左边菜单加载右边内容实例讲解
2013/03/04 Javascript
javascript实例--教你实现扑克牌洗牌功能
2014/05/15 Javascript
jquery获取节点名称
2015/04/26 Javascript
在JavaScript的正则表达式中使用exec()方法
2015/06/16 Javascript
AngularJS模块学习之Anchor Scroll
2016/01/19 Javascript
JavaScript中捕获与冒泡详解及实例
2017/02/03 Javascript
Angular2实现自定义双向绑定属性
2017/03/22 Javascript
AngularJS 支付倒计时功能实现思路
2017/06/05 Javascript
简单实现js进度条加载效果
2020/03/25 Javascript
基于JavaScript实现表格滚动分页
2017/11/22 Javascript
webpack学习教程之前端性能优化总结
2017/12/05 Javascript
浅谈webpack 自动刷新与解析
2018/04/09 Javascript
在小程序中使用腾讯视频插件播放教程视频的方法
2018/07/10 Javascript
JavaScript中七种流行的开源机器学习框架
2018/10/11 Javascript
JavaScript设计模式之装饰者模式实例详解
2019/01/17 Javascript
利用js-cookie实现前端设置缓存数据定时失效
2019/06/18 Javascript
js获取图片的base64编码并压缩
2020/12/05 Javascript
Django实现快速分页的方法实例
2017/10/22 Python
JavaScript中的模拟事件和自定义事件实例分析
2018/07/27 Python
python使用Plotly绘图工具绘制散点图、线形图
2019/04/02 Python
如何使用selenium和requests组合实现登录页面
2020/02/03 Python
Python中全局变量和局部变量的理解与区别
2021/02/07 Python
纯css3制作煽动翅膀的蝴蝶的示例
2018/04/23 HTML / CSS
俄罗斯鲜花递送:AMF
2020/04/24 全球购物
测试工程师岗位职责
2013/11/28 职场文书
2013年学期结束动员演讲稿
2014/01/07 职场文书
商务英语广告词大全
2014/03/18 职场文书
捐款活动总结
2014/08/27 职场文书
2016年社区六一儿童节活动总结
2016/04/06 职场文书
Python绘制分类图的方法
2021/04/20 Python