如果python中的一个类定义了 __call__ 方法,那么这个类它的实例就可以作为函数调用,也就是实现了 () 运算符,即可调用对象协议 下面是一个简单的例子: class TmpTest...: def __init__(self, x, y): self.x = x self.y = y def __call__(self, x, y):...self.x, self.y = x, y a = TmpTest(1, 2) a(4, 5) print(a.x, a.y) 4 5 在本文中不讨论装饰部分的内容,借用装饰器来讲解一个__call...__方法的使用,如果需要将一个类作为装饰器,那需要为这个类实现__call__方法,一个使用__call__来实现类装饰器的例子: class TmpTest: def __init__(self..., func): self.func=func def __call__(self, *args,**kwargs): result=self.func(*args
一、call和apply简介 call() 和 apply() 是预定义的函数方法。 两个方法可用于调用函数,两个方法的第一个参数必须是对象本身。 两个方法都使用了对象本身作为第一个参数。...两者的区别在于第二个参数: apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入,而call则作为call的参数传入(从第二个参数开始)。...二、call和apply的相同点和不同点 1. 区别 call传递的参数是序列1,2,3,4 apply传递的参数是集合型[1,2,3,4] 2....相同点 call和apply是替换前面函数内部的this指针以及传递参数。 功能:可以自动执行前面的函数 都有两个参数:a. 替换的对象 b....console.log(this,a,b,c);//{name: "张三", age: 20} 1 2 3 } method.call(obj,1,2,3); 方法2:使用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原型,进行改进 改进举例如下: <!
1. call 和 apply的区别 Function.prototype.call 和 Function.prototype.apply都是非常常用的方法,它们的作用一模一样,区别仅在于传入参数形式的不同...在这段代码中,参数1、2、3被放在数组中一起传入func函数,它们分别对应func参数列表中的x、y、z。...call是包装在apply上面的一颗语法糖,如果我们明确地知道函数接受多少个参数,而且想一目了然的表达形参和实参的对应关系,那么也可以用call来传递参数。...当使用call 或者 apply 的时候,如果我们传入的第一个参数为null,函数体内的this会指向默认的宿主对象,在浏览器中为window。 ?...这个时候我们可以用call来修正func函数的指向this,使其依然指向div。 ? 另外在本博客的"JavaScript中this的理解"也用apply来修正this,代码如下: ? (2).
obj.objAge; // 17 比较一下这两者 this 的差别,第一个打印里面的 this 指向 obj,第二个全局声明的 shows() 函数 this 是 window ; 1,call()...2,对比call 、bind 、 apply 传参情况下 ?...从上面四个结果不难看出: call 、bind 、 apply 这三个函数的第一个参数都是 this 的指向对象,第二个参数差别就来了: call 的参数是直接放进去的,第二第三第 n 个参数全都用逗号分隔...,直接放到后面 obj.myFun.call(db,'成都', ......bind 除了返回是函数以外,它 的参数和 call 一样。 当然,三者的参数不限定是 string 类型,允许是各种类型,包括函数 、 object 等等!
前言 回想起之前的一些面试,几乎每次都会问到一个js中关于call、apply、bind的问题,比如… 怎么利用call、apply来求一个数组中最大或者最小值 如何利用call、apply来做继承 apply...){ console.log(this.name); } } var person = new Person('qianlong'); person.showName(); 上面的代码中person...求数组中的最大和最小值 var arr = [34,5,3,6,54,6,-67,5,7,6,-8,687]; Math.max.apply(Math, arr); Math.max.call...,但是没有Array中的push、pop等方法。...length属性 ) 数组追加 在js中要往数组中添加元素,可以直接用push方法, var arr1 = [1,2,3]; var arr2 = [4,5,6]; [].push.apply
介绍:call与apply都属于Function.prototype的一个方法,所以每个function实例都有call、apply属性 1.改变函数内部的this指向: // 有一个局部的test2...console.log(this.id) var test2 = function(){ console.log(this) } function test3(){ console.log(this) } test3.call...(this) //改变了test2的this指针 test2.call(this) } 2.使用call来实现构造函数的继承。...function one(){ this.a = 1, this.b = 2, this.test = function(){ // console.log(this) } } //通过call来实现构造函数的继承...function two(){ one.call(this) console.log(this) } // 实例化 var oneObj = new one() twoObj = new two()
religion`); } getDetails() // undefined is the undefined religion 复制代码 所以,这里的"this"指向"window"对象(根据函数中"...那就是call, apply, bind出现的地方。...或者,我们可以说,"call"或者"apply"方法在getDetails函数中创造了一个"this"指向"religion"对象。...多次使用"call"和"apply"是一种解决方法,但是"bind"函数可以让这个过程更加容易。..."bind"方法创造了一个指向传入对象的"this"引用,这和"apply"或者"call"那样,但是其返回一个函数。 现在,在你的代码中,这个函数通过不同参数被多次使用。
前言 回想起之前的一些面试,几乎每次都会问到一个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
(obj2)) //sxm 对于call和apply的理解 要想理解上文第4点中的call调用改变this的具体实现原理,需要先了解call和apply的作用。...方法传入的参数中,第一个参数也是指定调用call的函数体内this对象的指向,从第二个参数开始往后,每个参数被依次传入函数中。...; 当在Function.prototype.call或Function.prototype.apply情况下,前面调用apply或call的函数体内的this原有指向被更改为指向apply或call方法中的第一个参数...中 4 [参数三:传入调用call方法的函数体内的参数2] 5 [参数四:传入调用call方法的函数体内的参数3] 6 ... 7 ) 如果只是想通过apply或call来借用某个函数方法进行某种运算...因为在非严格模式下,此时调用apply或call的函数体内的this会指向宿主环境中的全局对象;在严格模式下此时调用apply或call的函数体内的this会指向null。
call和apply实现相同的折叠的Demo ?...身为VRMMORPG(虚拟大规模线上角色扮演游戏)《刀剑神域〈SAO〉》中的其中一名玩家:桐人和其他一万个玩家才刚登入享受此游戏之时,游戏中的管理员对大家宣布了一个令人惊恐的消息── 那就是,现在唯一要登出此游戏的方法只有将这个游戏破关...,并且在这个游戏中GAME OVER的话,也就代表了现实世界中的“死亡”。.../image/jinshu.jpg"> 故事讲述的是从东京都西部被分割出来的这座都市中,“超能力开发”被列为学校课程的一部分...某一个暑假的日子,在家里的阳台上,他遇见了一位修女;这位少女自称自己的名字叫“茵蒂克丝”,并是从魔法的世界逃了出来,现在正在被魔法师追赶中。
由于对执行命令 CALL和EXEC的无知,数据库的无知,以前学过,忘记了。 还得加强学习啊。...就一直在那写代码call。 最后弄明白,是在数据库里面可以直接这样执行CALL,但是要加{}: ? ?...} 就一句话: exec是sqlplus的命令,只能在sqlplus(查了下 应该是 客户端操作)中使用; call是sql命令,任何工具都可以使用,call必须有括号,即使没有参数。...而写在代码中是下面这样的: public static void getconnectionDB(String spSQL) throws SQLException, InstantiationException...DbUtils.close(resultSet); DbUtils.close(csStmt); DbUtils.close(dbConn); } }在代码中执行时
JS中的call()和apply()方法 1、方法定义 call方法: 语法:call([thisObj[,arg1[, arg2[, [,.argN]]]]]) 定义:调用一个对象的一个方法,...说明: call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。...(sub,3,1); 这个例子中的意思就是用 add 来替换 sub,add.call(sub,3,1) == add(3,1) ,所以运行结果为:alert(4); // 注意:js 中的函数其实是对象...(this) 的意思就是使用 Animal对象代替this对象,那么 Cat中不就有Animal的所有属性和方法了吗,Cat对象就能够直接调用Animal的方法以及属性了....,只是在此说明call 的用法。
在JavaScript 中,call、apply 和 bind 是 Function 对象自带的三个方法,这三个方法的主要作用是改变函数调用过程中的 this 指向 1 apply Function.apply...= { firstName:"John", lastName: "Doe" } person.fullName.apply(person1, ["Oslo", "Norway"]); 2 call...Function.call(obj[,params...])...(person1, "Seattle", "USA")(); 可以从上面看出,使用方法基本和call一致,只是后面多了(),其实是bind不会立即执行对应的函数,只是返回对函数的引用。...那为什么要引入bind呢,是因为call和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
call和apply 1....改变上下文 obj.call(thisObj, arg1, arg2, ...); obj.apply(thisObj, [arg1, arg2, ...]); call和apply作用相同,都是把obj...唯一区别是apply接受的是数组参数,call接受的是连续参数。...使用call绑定,这时候就可以调用slice方法。 3....与call和apply不同的是,bind绑定后不会立即执行。
概要 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!
下面简单例子分别说明了在不同情况下使用call_user_func: //先引用,后执行 function _call($call){ echo $call++.'...'; return $call; } $rs = call_user_func('_call',1); var_dump($rs); //结果 //1 //2 //int(3) 先执行...,后引用 $arg = 1; call_user_func(function ($call){ echo ++$call.'...argNum); },$argOne,$argTwo); //结果为 int(1) array(2) { [0]=> int(1) [1]=> int(2) } int(2) 调用类方法: 调用类中的静态方法有两种形式...($obj,'_Two'),2,3,4); 最后: 和call_user_func函数类似的还有call_user_func_array,call_user_func_array的作用和call_user_func
apply,call,bine 这三兄弟经常让初学者感到疑惑。前两天准备面试时特地做了个比较,其实理解起来也不会太难。...call call() 与 apply() 类似,区别在于 apply() 的第二个参数为数组,而 call() 把参数跟在第一个参数后面,并且可以跟多个参数。...语法 (Syntax) fun.call(thisArg, arg1, arg2, arg3 ...)...在我们的印象中, list3 应该输出 [1, 2, 3] 但实际输出的却是 [37, 1, 2, 3]。...call() 和 bind() 则把参数按顺序依次传入。
如果不用call_user_func_array你会怎么做?一些PHP框架可以将$_GET参数自动映射到方法,就是这样实现的。...如果使用call_user_func_array,你就不用去判断方法的类型。
领取专属 10元无门槛券
手把手带您无忧上云