JS函数上下文规则包括什么,具体应用是怎样
Admin 2022-06-27 群英技术资讯 739 次浏览
今天就跟大家聊聊有关“JS函数上下文规则包括什么,具体应用是怎样”的内容,可能很多人都不太了解,为了让大家认识和更进一步的了解,小编给大家总结了以下内容,希望这篇“JS函数上下文规则包括什么,具体应用是怎样”文章能对大家有帮助。对象.方法()
对象打点调用它的方法函数,则函数的上下文是这个打点的对象。
function fn() {
console.log(this.a + this.b);
}
var obj = {
a: 66,
b: 33,
fn: fn
}
obj.fn();
输出结果:
99
var obj1 = {
a: 66,
b: 33,
fn: function () {
console.log(this.a + this.b);
}
}
var obj2 = {
a: 66,
b: 33,
fn: obj1.fn
}
obj2.fn();
输出结果:
7
function outer() {
var a = 11;
var b = 22;
return {
a: 33,
b: 44,
fn: function () {
console.log(this.a + this.b);
}
}
}
outer.fn();
输出结果:
77
function fun() {
console.log(this.a + this.b);
}
var obj = {
a: 1, b: 2, c: [{ a: 3, b: 4, c: fun }]
};
var a = 5;
obj.c[0].c();
输出结果:
7
函数()
圆括号直接调用函数,则函数的上下文是window对象。
var obj1 = {
a: 1, b: 2, fn: function () {
console.log(this.a + this.b);
}
}
var a = 3;
var b = 4;
var fn = obj1.fn;
fn();
输出结果:
7
function fun() {
return this.a + this.b;
}
var a = 1;
var b = 2;
var obj = {
a: 3,
b: fun(), // 适用规则2
fun: fun
}
var result = obj.fun(); // 适用规则1
console.log(result);
输出结果:
6
数组下标
数组(类数组对象)枚举出函数进行调用,上下文是这个数组(类数组对象)。
var arr = ['A', 'B', 'C', function () {
console.log(this[0]);
}];
arr[3]();
输出结果:
A
function fun() {
arguments[3]();
}
fun('A', 'B', 'C', function () {
console.log(this[1]);
});
输出结果:
B
(function(){})();
IIFE(立即可执行函数)中的函数,上下文是window对象。
var a = 1;
var obj = {
a: 2,
fun: (function () {
var a = this.a; // 适用规则1
return function () { // 适用规则4
console.log(a + this.a); // 2+1
}
})()
};
obj.fun();
输出结果:
3
setInterval(函数,时间);
setTimeout(函数,时间);
定时器、延时器调用函数,上下文是window对象。
var obj = {
a: 1, b: 2, fun: function () {
console.log(this.a + this.b);
}
}
var a = 3;
var b = 4;
setTimeout(obj.fun, 2000); // 适用规则5
输出结果:
7
var obj = {
a: 1, b: 2, fun: function () {
console.log(this.a + this.b);
}
}
var a = 3;
var b = 4;
setTimeout(function () {
obj.fun(); // 适用规则1
}, 2000);
输出结果:
3
DOM元素.onclick = function(){};
事件处理函数的上下文是绑定事件的DOM元素。
请实现效果:点击哪个盒子,哪个盒子就变红,要求使用同一个事件处理函数实现。
<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title>规则6:事件处理函数</title>
<style>
* {
margin: 0;
padding: 0;
}
body div {
float: left;
width: 100px;
height: 100px;
margin-right: 10px;
border: 1px solid #000;
}
</style>
</head>
<body>
<div id="box1">1</div>
<div id="box2">2</div>
<div id="box3">3</div>
<script>
function changeColor() {
this.style.backgroundColor = 'red';
}
var box1 = document.getElementById('box1');
var box2 = document.getElementById('box2');
var box3 = document.getElementById('box3');
box1.onclick = changeColor;
box2.onclick = changeColor;
box3.onclick = changeColor;
</script>
</body>
</html>
实现效果:

请实现效果:点击哪个盒子,哪个盒子在2000毫秒之后就变红,要求使用同一个事件处理函数实现。
与案例1的区别:需要备份上下文。
function changeColor() {
var self = this; // 备份上下文
setTimeout(function () {
self.style.backgroundColor = 'red';
}, 2000);
}
var box1 = document.getElementById('box1');
var box2 = document.getElementById('box2');
var box3 = document.getElementById('box3');
box1.onclick = changeColor;
box2.onclick = changeColor;
box3.onclick = changeColor;
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家详细介绍了JavaScript实现弹性导航效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章主要介绍了使用vue项目配置多个代理的注意点,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
vue修改网站图标的方法和流程是什么?一些朋友想要修改网站图标,但是不清楚要怎样做,因此下面给大家分享一下修改网站图标的流程供大家参考,感兴趣的朋友就跟随小编一起看看吧。
delete属性是在JavaScript中经常使用的删除对象的一个属性,但是对于新手用户们来说却不是很了解其使用方法,那么接下来我们就一起去看看如何使用JavaScript delete属性的吧。
这篇文章主要为大家介绍了Vue3 中有场景是 reactive 能做而 ref 做不了的使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008