本文是金旭亮老师网易云课堂的课程笔记,记录下来,以供备忘。

函数执行上下文

当函数运行时,通过this,函数可以获取它运行所需的外界环境的相关信息(比如某变量的值,另一个对象的引用等)。

this引用的对象会”变的”!

每次对函数的调用都有一个上下文对象,this关键字引用它。如果函数归属于某个对象,则this关键字将引用此对象,它就是本次函数调用的上下文。

         var obj = {
func: function () {
console.info("func():this=" + this);
}
};
obj.func();//func():this=[object Object]
var ref = obj.func;
ref();//func():this=[object Window]

函数对象的call方法

  • 所有函数都有一个call方法,此方法可以动态地指定函数调用的上下文对象(this引用它)
  • call方法的第一个参数代表本函数运行时的上下文对象,后面跟的参数函数调用的实参(如果有的话)。
         window.color = "red";
var o = { color: "blue" };
function sayColor() {
console.info(this,this.color);
}
sayColor(); //window "red"
sayColor.call(this); //window "red"
sayColor.call(window); //window "red"
sayColor.call(o); //Object "blue"

函数对象的apply方法

  • call可以接收可变数目的参数,而apply仅能接收两个参数,第一个是context对象,另一个是参数数组,数组中可以包容多个参数。
  • apply方法 参数为context对象与数组
       function Person(name) {
this.name = name; //this.name 属性Person对象,而name 是实参,两个虽同名但是不同个体。
}
var say = function (message) {
console.info((this.name || '无名氏') +
"说:“" + (message || '我什么也不想说了') + "”。");
}
say(); //无名氏 说:“ 我什么也不想说了“
var p1 = new Person("qiu");
say.apply(p1, ["这是qiu说滴"]); //qiu说:“这是qiu说滴”。
window.name = "唐僧";
say.apply(null, ["你想说你就说嘛,你不说我就说了"]); //唐僧说:“你想说你就说嘛,你不说我就说了”。

回调函数中的this

被回调函数showTime的执行上下文,与回调函数setInterval的一致,都是window.示例

         <h4 id="output"></h4>
<script type="text/javascript">
////什么是回调?
var output = document.getElementById('output');
//被回调的函数
function showTime() {
console.info(this);
if (!!output) { //转换成boolean值
output.innerHTML = new Date().toLocaleString();
}
}
//负责回调的函数
setInterval(showTime, 1000);
</script>

回调函数的执行上下文对象

那么问题来了,当回调一个对象的方法时,如果此方法需要访问对象中的属性会怎么样?

         var obj = {
outputElem: document.getElementById('output'),
showTime: function () {
this.outputElem.innerHTML = new Date().toLocaleString();
}
};
//当回调一个对象的方法时,如果此方法需要访问对象中的属性
//则会报告出错
setInterval(obj.showTime, 1000);

window对象中没有outputElem属性,因此,showTime()方法执行出错!

必须使用bind()方法,指定回调 函数在特定的上下文对象上执行。

       //设定被回调的函数,绑定到obj上
var callbackFunc = obj.showTime.bind(obj);
////现在工作正常了!
setInterval(callbackFunc, 1000);

JavaScript我学之八善变的this---函数执行上下文的更多相关文章

  1. 通俗易懂的来讲讲js的函数执行上下文

    0.开场白 在平时编写JavaScript代码时,我们并不会和执行上下文直接接触,但是想要彻底搞懂JavaScript函数的话,执行上下文是我们绕不过去的一个知识点. 1.执行上下文栈 JavaScr ...

  2. javascript 函数执行上下文

    在js里,每个函数都有一个执行的上下文,我们可以通过this来访问. 如: 全局函数 function test(){ var local = this; } 我们发现local等于window(do ...

  3. JavaScript delete用法,属性,特性,执行上下文,激活对象 综合篇

    一.问题的提出 我们先来看看下面几段代码,要注意的是,以下代码不要在浏览器的开发者工具(如FireBug.Chrome Developer tool)中运行,原因后面会说明: 为什么我们可以删除对象的 ...

  4. 深入理解JavaScript执行上下文、函数堆栈、提升的概念

    本文内容主要转载自以下两位作者的文章,如有侵权请联系我删除: https://feclub.cn/post/content/ec_ecs_hosting http://blog.csdn.net/hi ...

  5. javascript 执行上下文的理解

    首先,为什么某些函数以及变量在没有被声明以前就可以被使用,javascript引擎内部在执行代码以前到底做了些什么?这里,想信大家都会想到,变量声明提前这个概念: 但是,以下我要讲的是,声明提前的这个 ...

  6. 【进阶1-2期】JavaScript深入之执行上下文栈和变量对象(转)

    这是我在公众号(高级前端进阶)看到的文章,现在做笔记 https://mp.weixin.qq.com/s/hZIpnkKqdQgQnK1BcrH6Nw 阅读笔记 JS是单线程的语言,执行顺序肯定是顺 ...

  7. JavaScript学习系列之执行上下文与变量对象篇

    一个热爱技术的菜鸟...用点滴的积累铸就明日的达人 正文 在上一篇文章中讲解了JavaScript内存模型,其中有提到执行上下文与变量对象的概念.对于JavaScript开发者来说,理解执行上下文与变 ...

  8. Javascript 执行上下文 context&scope

    执行上下文(Execution context) 执行上下文可以认为是 代码的执行环境. 1 当代码被载入的时候,js解释器 创建一个 全局的执行上下文. 2 当执行函数时,会创建一个 函数的执行上下 ...

  9. 《浏览器工作原理与实践》<11>this:从JavaScript执行上下文的视角讲清楚this

    在上篇文章中,我们讲了词法作用域.作用域链以及闭包,接下来我们分析一下这段代码: var bar = { myName:"time.geekbang.com", printName ...

随机推荐

  1. PS中如何提高修改psd图片的效率(自动选择工具)

    在photoshop中制作图片的时候,一般要养成保留psd格式的习惯,纵然普通时候jpg,png格式常用,考虑到以后可能需要修改,也应该备份一下.如果考虑到以后需要修改,可每次成品保存成两个,一个ps ...

  2. Linux 学习 (十) 网络配置

    Linux网络管理 学习笔记 配置 IP 地址 ifconfig 命令临时配置 IP 地址 ifconfig eth0 192.168.0.200 netmask 255.255.255.0 #临时设 ...

  3. vs2017开发IOS(vs2017 xamarin 连接mac)

    这两天突然记起巨软的Visual Studio 2017 好像有说可以用C#开发IOS和Android应用,所以就自己去尝试了下生成过程. 相对与IOS来说,Android的生成过程还是比较容易的没有 ...

  4. 【NLP】Conditional Language Modeling with Attention

    Review: Conditional LMs Note that, in the Encoder part, we reverse the input to the ‘RNN’ and it per ...

  5. 如何从官网下载 Google Chrome 离线安装包

    1.打开 Chrome 浏览器主页:http://www.google.cn/chrome 2.地址栏最后的网址是这样的:http://www.google.cn/chrome/browser/des ...

  6. 通过crontab调度java -jar任务提示"nohup: failed to run command `java': No such file or directory"

    通过crontab无法运行,提示如标题的信息: 但直接在终端控制台执行sh和java -jar都可以: 网上给的提示解决方法,在.sh文件开始上面加上 source /etc/profile 然后cr ...

  7. 微服务下的容器部署和管理平台Rancher

    Rancher是什么 Rancher是一个开源的企业级容器管理平台.通过Rancher,企业再也不必自己使用一系列的开源软件去从头搭建容器服务平台.Rancher提供了在生产环境中使用的管理Docke ...

  8. 【Linux网络编程】TCP网络编程中connect()、listen()和accept()三者之间的关系

    [Linux网络编程]TCP网络编程中connect().listen()和accept()三者之间的关系 基于 TCP 的网络编程开发分为服务器端和客户端两部分,常见的核心步骤和流程如下: conn ...

  9. Numpy 系列(七)- 常用函数

    在了解了 Numpy 的基本运算操作,下面来看下 Numpy常用的函数.     数学运算函数 add(x1,x2 [,out]) 按元素添加参数,等效于 x1 + x2 subtract(x1,x2 ...

  10. 1.2浅谈Spring-Spring结构

    时隔很多天的我又回来....最近发展了一下自己的爱好,所以拖了很长时间. 前面我们从概念性上分析了spring的特性 这里我们附上Spring框架的结构图 我们简单的来说一些这个框架图 我们从下往上看 ...