所属分类:web前端开发
在jquery中,apply()方法用于改变this指向,使用另一个对象替换当前对象,是应用某一对象的一个方法,语法为“apply(thisobj,[argarray])”;参数argarray表示的是以数组的形式进行传递。
前端(vue)入门到精通课程:进入学习
Apipost = Postman + Swagger + Mock + Jmeter 超好用的API调试工具:点击使用
本教程操作环境:windows10系统、jquery3.2.1版本、Dell G3电脑。
call()方法和apply()方法的作用相同:改变this指向。
具体语法:
apply(thisobj,[argarray])
登录后复制
apply()方法与call()方法作用是差不多的,区别在于参数的传递形式上,apply()方法只有两个参数,thisobj参数与call()方法中的用法相同,第二个参数argarray是以数组的形式传递,这一点与call()不同,call()除thisobj外,可以传递多个单独的参数。
两个方法在参数的组织形式上稍有区别,功能差不多。
call方法的调用对象一般为某一个函数,函数本身也是一种对象。
第一个参数thisobj是函数对象新的上下文,根据thisobj对象的不同,函数的执行上下文可能会不一样,如果不传thisobj参数,默认的上下文是全局window.
示例如下:
例如:
<script>
var a = 1, b = 1;
function add(a, b)
{
alert(this.a + this.b);
}
var s = {};
s.a = 5;
s.b = 1;
add.call();
//alert(2)
add.call(s, 3, 1);
//alert(6)
</script>
登录后复制
add.call()不传入thisobj参数时,function add中this指向window,输出结果为2.
add.call(s,3,1),thisobj参数传入s时,function add中this指向s,所以输出结果为6.
function add(c, d){
return this.a + this.b + c + d;
}
var o = {a:1, b:3};
add.call(o, 5, 7); // 1 + 3 + 5 + 7 = 16 this指向o
add.apply(o, [10, 20]); // 1 + 3 + 10 + 20 = 34 this指向o
登录后复制
相关视频教程推荐:jQuery视频教程
以上就是jquery中apply()方法怎么用的详细内容,更多请关注zzsucai.com其它相关文章!