关于call 与 apply 那些事
1、定义:
call : 调用一个对象的一个方法,以另一个对象替换当前的对象。
apply : 应用某一对象的一个方法,用另一个对象替换当前的对象。
2、用法:
call:call(thisObj, arg1, arg2, ...); 说明:thisObj 通常表示一个对象,如果没有提供 thisObj 参数,那么 Global 对象将作为 thisObj 。第二个参数开始,如 arg1...可以传递任意形式参数。
apply : apply(thisObj, [argArray]); 说明:thisObj 通常表示一个对象,如果没有提供 thisObj 参数,那么 Global 对象将作为 thisObj。 第二个参数开始,必须是array 或 arguments。
3、区别:
两者区别在于第二个参数。
4、个人理解 :
其实就是把前一对象的方法应用到后一对象上(括号中的第一个参数)。也就是改变了this指针的指向。
5、啥也不说,上几个简单代码 :
function func1(name){
this.name = name;
this.showName = function(){
console.log(this.name);
}
}
function func2(name){
this.name= name;
}
var obj1 = new func1("func1");
var obj2 = new func2("func2");
obj1.showName();
obj2.showName(); //直接报错,因为obj2里没有 showName() 方法
obj1.showName.call(obj2); //这样就可以把 obj1 中的 showName() 方法给 obj2 用
6、用来实现继承
function func1(name){
this.name = name;
this.showName = function(){
console.log(this.name);
}
}
function func2(name){
func1.call(this,name);
}
var obj2 = new func2("func2");
obj2.showName();
var Person = function(name,age){
this.name = name;
this.age = age;
this.gender = ['man','woman'];
}
var Stu = function(name,age,high){
Person.call(this,name,age);
this.high = high;
this.showMessage = function(){
console.log('name:'+this.name+", age:"+this.age+", high:"+this.high+", gender:"+this.gender[0]);
}
}
new Stu("zhangsan","20","178").showMessage();
function Person(name,age){
this.name = name;
this.age = age;
this.sayHello = function(){
console.log(this.name);
}
}
function Print(){
this.funcName = "Print";
this.show = function(){
var msg = [];
for(var key in this){
if(typeof(this[key])!="function"){
msg.push([key,":",this[key]].join(""));
}
}
console.log(msg.join(" "));
}
}
function Student(name,age,grade,school){
Person.apply(this,arguments);
Print.apply(this,arguments);
this.grade = grade;
this.school = school;
}
var p1 = new Person("liang",80);
p1.sayHello();
var s1 = new Student("kobe",20,9,"aaaa");
s1.show();
s1.sayHello();
console.log(s1.funcName);
7,实践
(1)找出数组中最大的元素,
var arr = [5,3,8,1,0];
Math.max(arr); // 这样是不行的, 会提示 NaN
所以需要遍历,如下:
function getMax(arr){
var arrlength = arr.length;
var ret = 0;
for(var i=0; i<arrlength; i++){
ret = Math.max(ret, arr[i]);
}
return ret;
}
console.log(getMax(arr));
换用apply, 可以这样写
function getMaxForApply(arr){
return Math.max.apply(null, arr);
}console.log(getMaxForApply(arr));
两段代码达到了同样的目的,但是 getMaxForApply 却很优雅、简洁得多。
(2)数组追加
var arr1 = [1,2,3];
var arr2 = [4,5,6];
把 arr2 追加到 arr1 中。
arr1.concat( arr2 ); // concat 方法并不改变 arr1 本身
正常需要如下操作:
function addarr(arr1,arr2){
var arrlen = arr2.length;
for(var i=0; i<arrlen; i++){
arr1.push(arr2[i]);
}
}
使用Apply ,代码就变得很简洁
function addarr(arr1,arr2){
Array.prototype.push.apply(arr1,arr2);
return arr1;
}
关于call 与 apply 那些事的更多相关文章
- js中call、apply、bind那些事
前言 回想起之前的一些面试,几乎每次都会问到一个js中关于call.apply.bind的问题,比如- 怎么利用call.apply来求一个数组中最大或者最小值 如何利用call.apply来做继承 ...
- js中call、apply、bind那些事2
前言 回想起之前的一些面试,几乎每次都会问到一个js中关于call.apply.bind的问题,比如… 怎么利用call.apply来求一个数组中最大或者最小值 如何利用call.apply来做继承 ...
- CSharpGL(31)[译]OpenGL渲染管道那些事
CSharpGL(31)[译]OpenGL渲染管道那些事 +BIT祝威+悄悄在此留下版了个权的信息说: 开始 自认为对OpenGL的掌握到了一个小瓶颈,现在回头细细地捋一遍OpenGL渲染管道应当是一 ...
- call,apply,bind的用法
关于call,apply,bind这三个函数的用法,是学习javascript这门语言无法越过的知识点.下边我就来好好总结一下它们三者各自的用法,及常见的应用场景. 首先看call这个函数,可以理解成 ...
- js中bind,call,apply方法的应用
最近用js的类写东西,发现一个无比蛋疼的事,那就是封装的类方法中的this指针经常会改变指向,失去上下文,导致程序错误或崩溃. 比如: function Obj(){ this.type = &quo ...
- JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法
相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...
- 关于javascript中apply()和call()方法的区别
如果没接触过动态语言,以编译型语言的思维方式去理解javaScript将会有种神奇而怪异的感觉,因为意识上往往不可能的事偏偏就发生了,甚至觉得不可理喻.如果在学JavaScript这自由而变幻无穷的语 ...
- 关于angularjS与jQuery框架的那些事
这篇文章主要介绍了jQuery和angularJS的区别浅析,本文着重讲解一个熟悉jQuery的程序员如何应对angularJS中的一些编程思想的转变吗,需要的朋友可以参考下 最近一直研究angula ...
- javascript篇-----函数apply()和call()
转自:http://www.jb51.net/article/28013.htm 如果没接触过动态语言,以编译型语言的思维方式去理解javaScript将会有种神奇而怪异的感觉,因为意识上往往不可能的 ...
随机推荐
- mysql 学习(1)
1.从图中看到mysql是客户服务器模式. 2.我们如何操纵数据库? a.直接sql,各种编程语言, 3.客户端和服务器如何通信呢? 凡是c/s模式的都会自己的协议,但是都是基于TCP/IP协议,在l ...
- JavaScript高级程序设计8.pdf
基本包装类型 为了便于操作基本类型值,ECMAScript定义了3个特殊的引用类型Boolean,Number和String.这些类型与本章介绍的其他用类型相似,同时也具备与各自的基本类型相应的特殊行 ...
- xrdp远程 & watchdog 启用与测试 & WebRTC
sudo apt-get install xrdp sudo apt-get install vnc4server tightvncserver echo "xfce4-session&qu ...
- [转]C语言单引号和双引号的区别
单引号和双引号在C中的意义完全不同,包围在单引号中的一个字符只是编写整数的另一种方法.这个整数是给定的字符在实现的对照序列中的一个对应的值,即ASCII码值.因此在一个ASCII实现中,‘a’和014 ...
- JavaEE中遗漏的10个最重要的安全控制
本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划! JavaEE有一些超赞的内置安全机制,但它们远远不能覆盖应用程序要面临的所有威胁.很多常见攻击,例如跨站点脚本攻 ...
- mvcc摘抄
MVCC浅析原文:---->>>>>> http://blog.csdn.net/chosen0ne/article/details/18093187 在并发读写数 ...
- Docker的基本操作
容器基本操作 1.启动容器 $docker run image [COMMAND] [ARG…] run在新容器中执行命令 2.启动交互式容器 $docker run -i -t IMAGE /bin ...
- Spark1.0.0 监测方法
Spark1.0.0能够通过下面几种方式来对Spark应用程序进行监控: Spark应用程序的WebUI或者Spark Standalone的集群监控 指标,然后通过支持指标收集的集群监控 ...
- Swift: Initialization-1
初始化的过程包括为每一个存储属性设置一个初始值和其他步骤.通过定义构造函数来实现初始化的过程,跟oc的初始化函数不同,Swift的构造函数不返回一个值.它们的主要角色是确保一个类型的实例在初次使用前被 ...
- Hadoop流程---从tpch到hive
刚接触Hadoop,看了一周的Hadoop及其相应的组件,感觉效果不是很明显,于是将找个例子练一下手,跑一个流程,加深对hadoop的理解. 设计的流程如下: TPC_H--->HdFS---- ...