JS中call和apply函数用法实例分析
本文实例讲述了JS中call和apply函数用法。分享给大家供大家参考,具体如下:
call 函数
语法
obj.call(thisObj,arg[,arg2[,arg3[,...agr]]]);
简介
thisObj继承obj的属性和方法(obj原型链上的属性和方法不能被继承),后面的参数会当成obj的参数安装顺序传递进去。
示例
function animal(type,nickname){ this.type = type; this.nickname = nickname; this.sayHello = function(){ return 'hello'; } } function cat(name,type,nickname){ this.name = name; //cat继承animal animal.call(this,type,nickname); } console.log(new cat('wsscat','cut','tom')); /* cat { name: 'wsscat', type: 'cut', nickname: 'tom', sayHello: [Function] } */
apply 函数
语法
obj.apply(this[,argArray]);
简介
apply和call的作用差不多,都可以用来继承,区别在与apply只有两个参数,第二个参数必须是数组或者arguments对象。否则会报TypeError错误。如果继承的对象obj有多个参数,则会吧argArray的参数依次对应obj的每个参数。
示例
function animal(type,nickname){ this.type = type; this.nickname = nickname; this.syaHello = function(){ return 'hello'; } } function cat(name,type,nickname){ this.name = name; animal.apply(this,arguments); } console.log(new cat('wsscat','cut','tom')); /* cat { name: 'wsscat', type: 'wsscat', nickname: 'cut', syaHello: [Function] } */
总结
call
和apply
在功能是相同的。
相同点在于都是用于对象的继承,第一个参数都是thisObj.
不同点在于call可以有多个参数,从第二个参数开始往后的参数会依次传给被继承的对象做参数。apply只有两个参数,第二个参数必须是数组类型或者arguments对象类型,而且他会把数组中的元素依次传递给被继承的对象做参数。
通过以上几点,我们可以得到如果被继承的对象只有一个参数的可以使用call,如果被继承的对象有多个参数的,建议使用apply.
补充
js中可以实现多继承,只需要调用多次call或apply即可。如:
function animal(type,nickname){ this.type = type; this.nickname = nickname; this.syaHello = function(){ return 'hello'; } } function wscat(name,age){ this.name = name; this.age = age; this.sayMe = function(){ return 'my name:' + this.name + ', age:' + this.age; } } function cat(name,age,type,nickname){ //第一种使用call animal.call(this,type,nickname); wscat.call(this,name,age); //第二种使用apply //animal.apply(this,[type,nickname]); //wscat.apply(this,[name,age]); } console.log(new cat('wscat',2,'cat','tom'); /* cat { type: 'cat', nickname: 'tom', syaHello: [Function], name: 'wscat', age: 2, sayMe: [Function] } */
继承的优化
如果构造函数this绑定了太多的属性(比如一些共用的函数),示例化后就会照成浪费(因为this里的属性和方法实例化后会复制一份给新对象,多个对象之间的属性和方法互不干涉,对于一些可以共用的方法来就会造成浪费)
所以我们一般把共用的函数都放在原型链(prototype
)上。但是使用call和apply无法继承原型链上的属性和方法。
因此我们可以使用混合的而写法,使用原型链和(apply
或call
)组合的方式进行继承。
让子的原型链指向父的示例(父的实例化对象)。如:
cat.prototype = new animal();
让父的属性创建在子的this上。如:
animal.call(this[,arg]); //animal.apply(this[,argArray]);
具体代码如下:
function animal(type,nickname){ this.type = type; this.nickname = nickname; } animal.prototype.sayHello = function(){ return 'hello'; } function wscat(name,age){ this.name = name; this.age = age; } //这里是关键,原型链只能单继承, //不能同时继承多个原型链,所以要一级一级来。 wscat.prototype = new animal(); wscat.prototype.sayMe = function(){ return 'my name:' + this.name + ', age:' + this.age; } function cat(name,age,type,nickname){ animal.call(this,type,nickname); wscat.call(this,name,age); } cat.prototype = new wscat(); var obj = new cat('wscat',10,'cat','tom'); console.log(obj); //animal { type: 'cat', nickname: 'tom', name: 'wscat', age: 10 } console.log(obj.sayHello());//hello console.log(obj.sayMe()); /* my name:wscat, age:10 */
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
- 网页爬虫-R语言实现基本函数
- Python中的random模块用于生成随机数
- 简单易学的机器学习算法——极限学习机(ELM)
- 图片数据集太少?Keras Image Data Augmentation 各参数详解
- 备库归档删除策略失效的问题分析 (r7笔记第6天)
- 优化算法——梯度下降法
- Java基础-26(02)总结网络编程
- 记一次数据同步需求的改进(二) (r7笔记第5天)
- Python信贷数据处理与初步分析(ZIP解压)
- web前端之锋利的jQuery八:jQuery插件的使用(表单验证、表单提交)
- 优化算法——牛顿法(Newton Method)
- merge语句导致的CPU使用率过高的优化(r7笔记第4天)
- 由dual导致的一个潜在的监控问题(r7笔记第3天)
- 剑指Offer——编程题的Java实现
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Flutter 插件url_launcher简介
- Laravel框架查询构造器 CURD操作示例
- androidx下的fragment的lazy懒加载问题详解
- Thinkphp5框架简单实现钩子(Hook)行为的方法示例
- Android PhoneWindowManager监听屏幕右侧向左滑动实现返回功能
- Laravel框架创建路由的方法详解
- Android 进度条 ProgressBar的实现代码(隐藏、出现、加载进度)
- 解决Laravel blade模板转义html标签的问题
- laravel 配置路由 api和web定义的路由的区别详解
- Flutter 实现网易云音乐字幕的代码
- Yii框架通过请求组件处理get,post请求的方法分析
- PHP实现单文件、多个单文件、多文件上传函数的封装示例
- Android自定义控件单位尺寸实现代码
- Android中socket通信的简单实现
- Thinkphp5框架使用validate实现验证功能的方法