zoukankan      html  css  js  c++  java
  • 理解上下文与作用域

    一直以来没有对上下文(context)的定义,总有些模糊,没有认真地总结过,听到这个词,会想到看过的“上下文是函数执行环境”,“上下文是this”,但真的让自己去解释还真说不上来,故趁今日有空总结温故一番,有什么错误的,还望大家提出!

    《javascript权威指南》里是第8章函数导读页里有这样介绍到:

    函数使用它们实参的值 来计算返回值,成为该函数调用表达式的值。除了实参之外,每次调用还会拥有另外一个值——本次调用的上下文——这就是this关键字的传值。

    如果函数挂载在一个对象上,作为对象的一个属性,就称它为对象的方法。当通过这个对象来调用函数时,该对象就是此次调用上下文(context),也就是该函数的this的值 。用于初始化一个新创建的对象的函数称为构造函数。

    写一段简单的代码理解这段话:

    //定义一个对象
    var
    context = { foo: "bar", func : function(){ console.log(this);//打印上下文 return this.foo; } };
    //当通过这个对象来调用函数时,该对象就是此次调用上下文(context),也就是该函数的this的值 context.func();

    控制台输出结果:

    this代码了该函数的上下文(context),即对象context本身;

    作用域:函数的执行依赖于变量作用域,这个作用域是在函数定义时决定的,而不是函数调用时决定的。

    因为没理解好这条规则,故前两天晚上看了篇文章的示例没能理解,一直想不通 T T

    示例:( 一直在想为什么第二个bar输出的是1,不是2 )

    function foo(){
        var x = 1;
        return function() { alert(x); }
    };
    
    var bar = foo();
    
    bar(); // 1
    var x = 2 ;
    bar(); // 1

    好吧,作用域在函数定义时决定的,现在明白了,原谅我的无知......

    接下来,来把头脑内混乱的 “上下文?作用域?上下文?作用域?” 再度区分下吧。

    上下文(context)->this->挂载着变量与函数的对象(object-base)

    作用域->函数定义时决定->作用于函数(function-base)

    两者一个基于对象一个基于函数。

  • 相关阅读:
    leetcode35. search Insert Position
    leetcode26.Remove Duplicates from Sorted Array
    leetcode46.Permutation & leetcode47.Permutation II
    leetcode.5 Longest Palindromic Substring
    [转载] C++中new和malloc的区别
    [转载] C++中的自由存储区和堆
    xCode8以及iOS10 的新特性
    cell上添加倒计时,以及时差问题的解决
    cell的复用机制
    iOS 懒加载模式
  • 原文地址:https://www.cnblogs.com/marunzhou/p/5244586.html
Copyright © 2011-2022 走看看