未使用var声明的JavaScript变量是否变为全局变量?

时间:2012-11-11 07:18:21

标签: javascript jquery typescript

我在一个文件中有以下代码:

function refreshGridSuccess(responseText, entity) {

    oTable = $('#dataTable').dataTable({
        "sScrollX": "100%",

在另一个文件中我有:

$('#detailData')
        .on('click', '.sort-up', function (event) {
            event.preventDefault();
            var column = $(this).closest('th'),
                columnIndex = column.parent().children().index(column.get(0));
            oTable.fnSort([[columnIndex, 'asc']]);
            return false;
        })

我没有oTable的定义,除了这里。脚本似乎工作,所以这意味着oTable以某种方式被制作成全局变量?

现在我正在尝试使用Typescript,如果没有声明,它将不会接受Otable。有没有办法可以将oTable声明为对象,还是必须将其声明为与$('#dataTable').dataTable({})返回的对象类型相同的对象?

3 个答案:

答案 0 :(得分:3)

如果你处于全球范围,那么没有区别。 如果你在函数中,那么“var”将创建一个局部变量,“no var”将查找作用域链,直到它找到变量或命中全局作用域(此时它将创建它)。

在此处找到:What is the purpose of the var keyword and when to use it (or omit it)?

答案 1 :(得分:2)

是的,未使用var声明的变量将变为全局变量。当在函数范围之外使用时,它不一定是必需的,但是,使用函数中定义的全局定义变量会导致不可预测的结果。

“在这些情况下未能声明变量很可能会导致意外结果。因此,在ECMAScript 5严格模式下,在函数内部为未声明的变量赋值会引发错误。” - https://developer.mozilla.org/en-US/docs/JavaScript/Reference/Statements/var

答案 2 :(得分:1)

你是对的。没有var声明的变量被视为全局变量。如果您在浏览器中,则该范围为window

另请注意,Javascript变量是函数范围的。这意味着你有这样的代码:

function test()
{
   for (var key in someObject)
   {
      var foo = 'bar';
   }
}

相当于:

function test()
{
   var foo, key;
   for (key in someObject)
   {
      foo = 'bar';
   }
}

var声明置于哪个块并不重要,实际声明发生在函数的开头。如果你想谷歌它,也称为variable hoisting

现在关于Typescript,我还没有机会玩它。但我假设您在使用变量之前仍然可以var oTable;吗?