JS中的call()方法和apply()方法用法总结,以及方法体中this的定义
2023-09-14 09:11:18 时间
1. 每个函数都包含两个非继承而来的方法:call()方法和apply()方法。
2. 相同点:这两个方法的作用是一样的。
都是在特定的作用域中调用函数,等于设置函数体内this对象的值,以扩充函数赖以运行的作用域。
一般来说,this总是指向调用某个方法的对象,比如:在<script>中直接调用了某个方法function(){ };
<script> function Say(){ var othis = this; console.log(this); } //当我们直接在页面调用Say()的时候,函数体内的this就是默认指向window; Say(); //每个方法在调用时,都是需要有对象去调用它。方法就是挂载在对象上的属性或者武器; //大家可以看看jQuery和其它一些js轻量级的框架对象。 //方法都是挂载在jQuery这个对象上。 //如果是在按钮btn对象上点击触发Say()函数; //Say方法体里面的this指向的就是当前触发它的btn; </script> <body> <input type="button" class="btn" onclick="Say()"></input> </body>
但是使用call()和apply()方法时,就会改变this的指向。
call()方法使用示例:
//例1 <script> window.color = 'red'; document.color = 'yellow'; var s1 = {color: 'blue' }; function changeColor(){ console.log(this.color); } changeColor.call(); //red (默认传递参数) changeColor.call(window); //red changeColor.call(document); //yellow changeColor.call(this); //red changeColor.call(s1); //blue </script> //例2 var Pet = { words : '...', speak : function (say) { console.log(say + ''+ this.words) } } Pet.speak('Speak'); // 结果:Speak... var Dog = { words:'Wang' } //将this的指向改变成了Dog Pet.speak.call(Dog, 'Speak'); //结果: SpeakWang
apply()方法使用示例:
//例1 <script> window.number = 'one'; document.number = 'two'; var s1 = {number: 'three' }; function changeColor(){ console.log(this.number); } changeColor.apply(); //one (默认传参) changeColor.apply(window); //one changeColor.apply(document); //two changeColor.apply(this); //one changeColor.apply(s1); //three </script> //例2 function Pet(words){ this.words = words; this.speak = function () { console.log( this.words) } } function Dog(words){ //Pet.call(this, words); //结果: Wang Pet.apply(this, arguments); //结果: Wang } var dog = new Dog('Wang'); dog.speak();
3. 不同点:接收参数的方式不同。
- apply()方法 接收两个参数,一个是函数运行的作用域(this),另一个是参数数组。
语法:apply([thisObj [,argArray] ]);
,调用一个对象的一个方法,2另一个对象替换当前对象。
说明:如果argArray不是一个有效数组或不是arguments对象,那么将导致一个
TypeError,如果没有提供argArray和thisObj任何一个参数,那么Global对象将用作thisObj。
- call()方法 第一个参数和apply()方法的一样,但是传递给函数的参数必须列举出来。
语法:call([thisObject[,arg1 [,arg2 [,...,argn]]]]);
,应用某一对象的一个方法,用另一个对象替换当前对象。
说明: call方法可以用来代替另一个对象调用一个方法,call方法可以将一个函数的对象上下文从初始的上下文改变为thisObj指定的新对象,如果没有提供thisObj参数,那么Global对象被用于thisObj。
使用示例
function add(c,d){ return this.a + this.b + c + d; } var s = {a:1, b:2}; console.log(add.call(s,3,4)); // 1+2+3+4 = 10 console.log(add.apply(s,[5,6])); // 1+2+5+6 = 14
转自:https://www.cnblogs.com/sghy/p/7646633.html
相关文章
- 字符串的方法_js字符串包含另一个字符串
- js对象拷贝方法
- js 截取字符串的三种方法「建议收藏」
- js清除浏览器缓存的几种方法(项目总结)「建议收藏」
- JS刷新当前页面的方法总结
- JS实现继承的几种方法总结
- js实现阶乘算法的三种方法
- 用JS获取地址栏url参数的方法_js的url是啥
- 总结几个对象转数组的方法是_js将对象转为数组
- js正则表达式的使用详解编程语言
- JS判断是否是数组:使用isArray()方法
- JS every()方法:检测数组元素是否全部符合指定条件
- JS some()方法:检测数组中是否存在符合条件的元素
- JS createDocumentFragment()方法:创建文档片段
- 创建JS文件:在Linux下实现自动化任务(linux创建js文件)
- JS函数验证总结(方便js客户端输入验证)
- JS随机生成不重复数据的实例方法
- 使用Node.js做FunctionTest实现方法
- 在js文件中写el表达式取不到值的原因及解决方法
- js中同步与异步处理的方法和区别总结
- js校验表单后提交表单的三种方法总结
- js二维数组定义和初始化的三种方法总结
- js冒泡、捕获事件及阻止冒泡方法详细总结
- js跨域访问示例(客户端/服务端)
- node.js中的fs.mkdirSync方法使用说明
- JS打开新窗口防止被浏览器阻止的方法