首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

jscall和apply

一、call和apply简介 call() 和 apply() 是预定义的函数方法。 两个方法可用于调用函数,两个方法的第一个参数必须是对象本身。 两个方法都使用了对象本身作为第一个参数。...两者的区别在于第二个参数: apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入,而call则作为call的参数传入(从第二个参数开始)。... JavaScript 严格模式(strict mode)下, 调用函数时第一个参数会成为 this 的值, 即使该参数不是一个对象。... JavaScript 非严格模式(non-strict mode)下, 如果第一个参数的值是 null 或 undefined, 它将使用全局对象替代。...二、call和apply的相同点和不同点 1. 区别 call传递的参数是序列1,2,3,4 apply传递的参数是集合型[1,2,3,4] 2.

1.5K30

jscall与apply用法

前天去面试,有个gg问了一些js知识,其中有一道call与apply用法的题目,尽管365天前用过call方法,但当时还是没能答上来,今天深入总结一下 call和apply,它们的作用都是将函数绑定到另外一个对象上去运行...调用call方法,第二个参数属于函数对象func2的参数,因此alert(x)为第二个参数func2 二、call 继承用法与改进 js使用call模拟继承 测试代码: <!...(this); // call for A baseB.call(this); // call for B } window.onload = function() {...: function baseA() // base Class A { this.memberA = "baseA member";   // member改成memberA,以区分baseB的...因为每次函数(类)定义了成员方法,都会导致实例有副本,因此可以借助prototype原型,进行改进 改进举例如下: <!

2.7K10
您找到你想要的搜索结果了吗?
是的
没有找到

jscall、apply、bind那些事

前言 回想起之前的一些面试,几乎每次都会问到一个js关于call、apply、bind的问题,比如… 怎么利用call、apply来求一个数组中最大或者最小值 如何利用call、apply来做继承 apply...求数组的最大和最小值 1234567 var arr = [34,5,3,6,54,6,-67,5,7,6,-8,687];Math.max.apply(Math, arr);Math.max.call...,-8,687); 将伪数组转化为数组 js的伪数组(例如通过document.getElementsByTagName获取的元素)具有length属性,并且可以通过0、1、2…下标来访问其中的元素...,但是没有Array的push、pop等方法。...length属性 ) 数组追加 js要往数组添加元素,可以直接用push方法, 1234567 var arr1 = [1,2,3];var arr2 = [4,5,6];[].push.apply

1.7K50

划重点:js的this、call、apply

jsthis有4种指向,分别为: 作为对象的方法调用 作为普通函数调用 构造器调用 Function.prototype.call或Function.prototype.apply调用 1、当作为对象的方法调用时...getName方法赋值给新的变量func2时,func2就是一个全局作用域中的普通函数,而非obj对象的方法,已经与getName方法是两个完全独立的方法,拥有完全不同的作用域上下文*/ 3、构造器调用...this 先要理解js的构造器。...因为非严格模式下,此时调用apply或call的函数体内的this会指向宿主环境的全局对象;严格模式下此时调用apply或call的函数体内的this会指向null。...延伸应用: 理解了this、call、apply后,实际js开发,可以很方便的实现对象的继承 继承demo1: 1var Parent = function(){ 2 this.name

95420

JScall apply bind的用法

谁调用当前的属性或者方法的,它就是谁 /* 2.1.bind方法作用 修改函数或者方法的this为指定的对象, 并且会返回一个修改之后的新函数给我们 注意点...: bind方法除了可以修改this以外, 还可以传递参数, 只不过参数必须写在this对象的后面 */ //call apply bind修改this的.../*call:修改函数或者方法的this为指定的对象, 并且会立即调用修改之后的函数 注意点: call方法除了可以修改this以外, 还可以传递参数, */.../*apply:修改函数或者方法的this为指定的对象, 并且会立即调用修改之后的函数 注意点: apply方法除了可以修改this以外, 还可以传递参数, 只不过参数必须通过数组的方式传递...test(10,20); window.test(); let fn=test.bind(obj,10,20); fn(); test.call

2.9K30

JS的bind、apply、call的理解

概要 call、apply、bind 都是用来修改函数的this, 传参时,call是一个个传参,apply是数组形式传参,call和apply立即执行并且返回值是你调用的方法的返回值,若该方法没有返回值..."); } }; let b = { name: "小红" }; a.play("小刚"); a.play.bind(b)("小刚"); 显示 小明和小刚一块玩 小红和小刚一块玩 Call..." + name1 + "、" + name2 + "一块玩"); } }; let b = { name: "小红" }; a.play("小刚", "小李"); a.play.call...name: "小红" }; a.play("小刚", "小李"); a.play.apply(b, ["小刚", "小李"]); 显示 小明和小刚、小李一块玩 小红和小刚、小李一块玩 结论: call...、apply、bind 是Function.prototype下的方法,作用是执行一下目标函数,执行时顺便把目标函数的this改一下,然后把结果输出,执行后,不会影响原函数的this!

92610

jscall方法的理解和思考

最近接手前端的工作,对当前项目中自制的js框架下,js的使用产生了非常多的困惑.尤其是js的类,对象,函数,this等等相互之间的关系和转换,以前学过也忘得差不多了,现在基本相当于重新看. js的函数有可以有好几种解释...Function是个函数对象,也可以认为是个类,所有定义的函数都是Function类的对象,我定义的user也是对象,并且可以调用Function里面的方法 user.call(xxx);当我使用user...调用call方法时,他是作为对象来使用,调用的是Function类里面的call方法,这个方法的作用是调用这个函数并且把传递进去的参数覆盖函数里面的this .第一个参数是覆盖函数里面的this , 剩下的参数是作为这个函数的参数传进去...function user(name){ console.log('我被调用了,this被覆盖了',this,',参数传进来了',name); }; user.call({},'陶士涵');

92630

js call 和 apply

call   call方法与apply方法的第一个参数是一样的,只不过第二个参数是一个参数列表   非严格模式下当我们第一个参数传递为null或undefined时,函数体内的this会指向默认的宿主对象...,浏览器则是window var test = function(){ console.log(this===window); } test.apply(null);//true test.call...(undefined);//true 用法   "劫持"别人的方法   此时foo的logName方法将被bar引用 ,this指向了bar var foo = { name:"mingming"...(this, name); } var cat = new Cat("Black Cat"); cat.showName(); //Black Cat 实际开发,经常会遇到this...(this);//test } 当然你也可以这样做,不过ECMAScript 5的strict模式下,这种情况下的this已经被规定为不会指向全局对象,而是undefined: window.id="

1.3K20

js call方法_recall

最近又遇到了JacvaScriptcall()方法和apply()方法,而在某些时候这两个方法还确实是十分重要的,那么就让我总结这两个方法的使用和区别吧。 1....都是特定的作用域中调用函数,等于设置函数体内this对象的值,以扩充函数赖以运行的作用域。...changeColor.call(window); //red changeColor.call(document); //yellow changeColor.call(this); //...call()方法 第一个参数和apply()方法的一样,但是传递给函数的参数必须列举出来。 语法:call([thisObject[,arg1 [,arg2 [,......说明: call方法可以用来代替另一个对象调用一个方法,call方法可以将一个函数的对象上下文从初始的上下文改变为thisObj指定的新对象,如果没有提供thisObj参数,那么Global对象被用于thisObj

84920

“”python什么意思

本文中,我们将详细了解 Python 的 // 运算符。 要在 Python 中进行楼层划分,请使用双斜杠 // 运算符。...例 以下程序使用 Python 的 // 和 / 运算符返回第一个数字的楼层除法和除以第二个数字 − # input number 1  inputNumber_1 = 10 # input number...注意 − 如果我们用负数进行楼层除法,结果仍将向下舍入(最接近的整数) 双斜杠 // 运算符函数类似于 math.floor() Python ,math.floor() 与双斜杠 // 运算符一样...例 因为它们幕后做同样的事情,math.floor() 是 // 运算符的替代品。...division of inputNumber_1 by inputNumber_2 =  3 The floordiv method returns the same result as =  3 结论 本教程

5.2K40

Js apply() call()使用详解

Js apply方法详解 我一开始看到javascript的函数apply和call时,非常的模糊,看也看不懂,最近在网上看到一些文章对apply方法和call的一些示例,总算是看的有点眉目了,在这里我做如下笔记...主要我是要解决一下几个问题: apply和call的区别在哪里 什么情况下用apply,什么情况下用call apply的其他巧妙用法(一般什么情况下可以使用apply) 我首先从网上查到关于apply...和call的定义,然后用示例来解释这两个方法的意思和如何去用....call示例 Studen函数里面可以将apply修改成如下: Person.call(this,name,age); 这样就ok了 3.什么情况下用apply,什么情况下用call 在给对象参数的情况下...(Person.call(this,age,name,grade)); 4.apply的一些其他巧妙用法 细心的人可能已经察觉到,我调用apply方法的时候,第一个参数是对象(this), 第二个参数是一个数组集合

1.4K60

区别和详解:jscall()和apply()的用法

1、关于call()和apply()的疑点: apply和call的区别在哪里 什么情况下用apply,什么情况下用call apply的其他巧妙用法(一般什么情况下可以使用apply) 2、语法和参数分析...(Person.call(this,age,name,grade)); 5、apply的一些其他巧妙用法 细心的人可能已经察觉到,我调用apply方法的时候,第一个参数是对象(this), 第二个参数是一个数组集合..., 调用Person的时候,他需要的不是一个数组,但是为什么他给我一个数组我仍然可以将数组解析为一个一个的参数....(sub,3,1); 分析:这个例子的意思就是用 add 来替换 sub,add.call(sub,3,1) == add(3,1) ,所以运行结果为:alert(4); // 注意:js 的函数其实是对象...这样 Class2 就继承Class1了,Class1.call(this) 的 意思就是使用 Class1 对象代替this对象,那么 Class2 不就有Class1 的所有属性和方法了吗,c2

63620
领券