- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有人可以解释一下 JS 中的变量作用域,因为它适用于对象、函数和闭包吗?
最佳答案
Javascript 中的每个变量都是对象的命名属性。例如:-
var x = 1;
x 被添加到全局对象中。全局对象由脚本上下文提供,并且可能已经具有一组属性。例如,在浏览器中,全局对象是 window。浏览器中与上述行等效的内容是:-
window.x = 1;
现在如果我们将其更改为:-
function fn()
{
var x = 1;
}
何时 fn
被称为创建的新对象称为执行上下文,也称为范围(我交替使用这些术语)。 x
作为属性添加到此范围对象。因此每次调用fn
将获得它自己的作用域对象实例,因此获得它自己的附加到该作用域对象的 x 属性实例。
现在让我们更进一步:-
function fnSequence()
{
var x = 1;
return function() { return x++; }
}
var fn1 = fnSequence();
var fn2 = fnSequence();
WScript.Echo(fn1())
WScript.Echo(fn2())
WScript.Echo(fn1())
WScript.Echo(fn2())
WScript.Echo(fn1())
WScript.Echo(fn1())
WScript.Echo(fn2())
WScript.Echo(fn2())
注意:替换 WScript.Echo
在您的上下文中写入标准输出的任何内容。
您应该得到的序列是:-
1 1 2 2 3 4 3 4
那么这里发生了什么?我们有fnSequence
它初始化变量 x
为 1 并返回一个匿名函数,该函数将返回值 x
然后递增它。
首次执行此函数时,会创建一个作用域对象并创建一个属性 x
添加到值为 1 的范围对象。在同一执行对象中还创建了一个匿名函数。每个函数对象都有一个作用域属性,该属性指向创建它的执行上下文。这将创建所谓的作用域链,我们将在稍后介绍。 fnSequence
返回对此函数的引用并存储在 fn1
.
请注意fn1
现在指向匿名函数,并且匿名函数有一个指向作用域对象的作用域属性,该作用域对象仍然具有 x
附加属性。这称为 closure
其中,在为其创建的函数完成执行后,执行上下文的内容仍然可以访问。
现在,当分配给 fn2
时,会发生相同的顺序。 fn2
将指向在 fnSequence
时创建的不同执行上下文中创建的不同匿名函数。第二次被调用。
当 fn1
持有该函数时会发生什么是第一次执行吗?创建一个新的执行上下文来执行匿名函数。从标识符 x
中可以找到返回值。 。检查函数的范围对象是否有 x
属性,但没有找到。这就是作用域链发挥作用的地方。未能找到 x
在当前执行上下文中,JavaScript 获取函数范围属性所持有的对象并查找 x
那里。它找到它是因为函数作用域是在 fnSequence
的执行中创建的。 ,检索其值并递增它。因此输出 1 且 x
在此范围内增加到2。
现在当fn2
执行后,它最终附加到不同的执行上下文,其 x
属性仍然是1。因此执行fn2
也得出 1。
如您所见 fn1
和fn2
每个生成自己独立的数字序列。
关于javascript - OO JavaScript : Definitive explanation of variable scope,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/99927/
我在这里有我的 javascript 代码: define(['controllers/controllers', 'services/alerts'], function(module) {
的意义是什么scope = scope-token *( SP scope-token ) scope-token = 1*( %x21 / %x23-5B / %x5D-7E ) 在 RFC6749
我是 AngularJS 的新手。我试图找出这两个 Controller 定义之间的区别: app.controller('simpleController', ['$scope', function
似乎所有 Guice 的开箱即用 Scope 实现本质上都是基于线程的(或完全忽略线程): Scopes.SINGLETON和 Scopes.NO_SCOPE忽略线程并且是边缘情况:全局范围和无范围。
如果这个问题涉及的是一个常见问题,我很抱歉,但我发现这个问题非常抽象,并且无法真正为其构建一个好的 Google 搜索词。 我试图理解并找到 Maven 中提供的依赖项的用例。我的想法是这样的: 假设
假设我有以下 Controller angular.module('scopeExample', []) .controller('MyController', ['$scope', func
当前在TmThemeEditor上注册的243种配色方案中, 我注意到几乎没有人使用范围选择器运算符。 对于以下情况,运算符非常有用: (text.html | text.xml) & (meta.t
我有一些行为不符合预期的代码......我在 AngularJS Controller 中有一个事件监听器,如下所示: $scope.$on("newClipSelected", function(e
首先,如果帖子太长,我深表歉意。另外,为了以防万一这会以某种方式干扰您可能给我的答案,我不会以通常的方式定义我的 Controller 。相反,我关注http://www.technofattie.c
我有一个模式,其中许多项目类型都是“可编辑的”。这意味着我有很多模板(每种可编辑项目类型一个),这些模板期望具有唯一的字段,但具有通用功能(编辑、保存、取消编辑、删除等)。这些常见功能导致 Contr
$evalAsync 和 $applyAsync 之间有什么区别?我的理解是,当我从指令中使用 $evalAsync 时,表达式将在浏览器呈现之前进行计算。 举个例子,如果我想滚动到页面上的特定位置但
我试图为一个 $scope 变量提供另一个 $scope 变量的值。有人能告诉我出了什么问题吗?查看简单的 plunker 了解详细信息: http://plnkr.co/edit/TlKnd2fM5
我有以下一段 Angular 代码 $scope.prepare = function(){ $scope.elems = [1,2,3]; }; $scope.action = functio
我正在关注 Angularjs 的官方教程,但我陷入了第 2 步。 这是一个片段,我不明白 $scope:scope 的含义, describe('PhoneListCtrl', function()
根据文档, Global: Component is shared among all users. Session: Separate instances of the component are
显示作用域变量,类似于 Angularjs 中的 ng-repeat 元素 这些是我的范围变量 $scope.published = true; $scope.count = 3; 我还有一个名为 l
我是 Angular 的新手,我想在普通的 javascript 中做一些非常简单的事情,但我无法找到如何在 Angular 中正确地做到这一点! 我想设置一个通用函数来清除输入文本字段: 我有这个
在article中发现了这样一个idea : Notice how the value function takes the scope as parameter (without the $ in
注释部分将位于 $scope.$on 下。我需要将 options 返回到我保存 $scope.$emit 的地方。请帮助!!! if (gridConfig.Batch) {
我有一个带有 2 个作用域的 Controller : app.controller('search', function($scope) { $scope.value1 = '';
我是一名优秀的程序员,十分优秀!