javascript - JavaScript 行为的范围

标签 javascript scope photoshop-script

这是一个简单的脚本,用于记录 Photoshop 文件中的文本内容。

var numOfLayers = app.activeDocument.layers.length;
var resultStr = "";

doAllLayers();
alert(resultStr);

function addToString(alayer)
{
  if (alayer.kind == "LayerKind.TEXT")
  {
    var c = alayer.textItem.contents;
    resultStr += c;
  }
}

// main loop
function doAllLayers()
{
  for (var i = numOfLayers -1; i >= 0; i--)
  {
      var thisLayer = app.activeDocument.layers[i];
      addToString(thisLayer);
  }
}

它工作正常,但我确实应该将一个字符串传递到函数中以添加到自身,但它工作正常。 JavaScript 的范围如何允许这种情况发生?声明的局部变量是否仍然可以被函数访问,或者这是我缺少的另一个技巧?

最佳答案

以下是 JavaScript 中变量作用域的一些基本规则:

  • 如果使用 var 关键字定义,则该变量是函数作用域的。也就是说,变量的作用域将是最近的包含函数,或者如果没有包含函数,则将作用域限定为全局上下文。 示例:
   
// globally-scoped variable (no containing function)
var foo = 'bar';

function test() {
    // function-scoped variable
    var foo2 = 'bar2';

    if (true) {
        // still function-scoped variable, regardless of the if-block
        var foo3 = 'bar3';
    }

    // see?
    console.log(foo3); // --> 'bar3'
}
  • 如果使用 let 关键字 (ES6+) 定义,则该变量是 block 作用域的(此行为更类似于大多数其他 C 系列语法语言)。示例:
   
// error: top level "let" declarations aren't allowed
let foo = 'bar';

function test() {
    // block-scoped variable (function are blocks, too)
    let foo2 = 'bar2';

    if (true) {
        // block-scoped variable (notice the difference
        // from the previous example?)
        let foo3 = 'bar3';
    }

    // uh oh?
    console.log(foo3); // --> ReferenceError: foo3 is not defined
}
  • 如果既没有使用 var 也没有使用 let 关键字定义(例如 foo = bar),则该变量的作用域为全局上下文。示例:
   
// globally-scoped variable
foo = 'bar';

function test() {
    // also globally-scoped variable (no var or let declaration)
    foo2 = 'bar2';

    if (true) {
        // still a globally-scoped variable
        foo3 = 'bar3';
    }
}

test();
console.log(foo, foo2, foo3); // 'bar', 'bar2', 'bar3'

在所有这些情况下,在变量范围内定义的函数仍然可以访问变量本身(从技术上讲,您正在创建一个闭包,如 numOfLayersresultStr 变量在词法上位于 addToStringdoAllLayers 函数的范围内)。

请注意,范围界定规则在技术上比这更微妙,但此时您最好阅读一篇更深入的文章。

关于javascript - JavaScript 行为的范围,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31536675/

相关文章:

用于编程 Photoshop 命令的 Javascript

javascript - 使用 JSON.stringify 时将原型(prototype)函数添加回返回的 Google Maps API 对象

javascript - 时间跟踪解析器

javascript - 如何加载选择?

c - 变量在函数和内存中的局部性

html - 如何在组件 View 中访问根作用域

c# - 检查和检索集合中第一项的最佳方法是什么?

javascript - 如何在不改变对象的情况下更改对象的属性?

javascript - 添加后清空 <li> 标签

javascript - 为什么这个 window.open 在 Chrome 和 FF 上有效,但在 IE 上无效?