0

我正在搜索将窗口对象访问到函数中(实际上是一个 ajax 回调函数,但没关系)。所以,我找到了一个 tuto,那个人解释了我的问题以及为什么我有这个问题,但他没有解决它。

好吧,当我想访问窗口对象并创建一个警报时,该变量是未定义的。我明白为什么(我认为)。这是因为当全局变量在函数中时,该函数中的所有内容都受到保护。

这是他的代码:

(function(){
    var foo = "Hello, window";

    var bar = function(){
         var foo = "Hello, function";

         alert(window.foo);
    };

    bar();
}());

所以,我的问题是完全一样的。我有一个对象(可以动手操作,但并不重要)。

var hotTraitement = new Handsontable

我在全局中定义它。所以它可以代表foo = "Hello, window"。我正在尝试在我的回调函数中使用它:

function callback(){
    alert(window.hotTraitement);
} 

它是未定义的。所以我不知道如何在我的函数中获取我的对象,tuto 也没有解释它。有人能帮助我吗 ?

(如果有人想要,这里是教程的链接:https: //www.youtube.com/watch? v=VSgSNQ1-KBo&spfreload=10 )

编辑 :

这是我的整个代码:

<script>
//Where I define my object "hotTraitement"
var container = document.getElementById('tab_traitement');
var hotTraitement = new Handsontable(container, {
    data: data_traitement,
    stretchH: 'all',
    minSpareRows: 1,
    observeChanges : true,
    rowHeaders: false,
    colHeaders: false,
    contextMenu: true
});
</script>

//The function where I want to get that object
<script>
function insertTraitementCallback(responseObject,ioArgs)
{   
    alert(hotTraitement);   
}

</script>

//My ajax request where I call my callback function
<script type="text/javascript">
    $(document).ready(function()
    {
        $('#submit_button_traitement').click(function()
        {
            $.post("ajaxUpdate.php",{arr:data_traitement,id_essai,table,idTable}, insertTraitementCallback,'json');         
        });
    });

</script>
4

2 回答 2

1

好吧,您的问题是外部foo不是全局的。一切都在函数内部,这意味着您的变量不附加到window,而是附加到本地函数范围。

您无法访问外部的唯一问题foo是因为您正在使用内部遮蔽它foo。实用、理智和简单的解决方案是简单地避免隐藏名称:

(function(){
    var foo = "Hello, outer";

    var bar = function(){
         var foo2 = "Hello, function";

         alert(foo);  // Hello, outer
    };

    bar();
}());
于 2015-08-10T08:05:57.803 回答
0

您的 Foo 变量在上面的代码中不是全局范围,而是在 IIFE 范围内。要使其全局化(因此可以以您希望在此处使用它的方式访问),您需要在 IIFE 之外声明它。或者,如果您将 IIFE 的结果分配给全局范围内的变量,并从中返回一个对象,您就可以将返回的对象中的方法作为您描述的回调引用。这通常用于命名 JavaScript。您可以在此处标题为“模块模式:私有数据和私有初始化”的部分中找到类似方法的更多详细信息:http://www.2ality.com/2011/04/modules-and-namespaces-in-javascript。 .html _ 本质上,您返回一个在其中定义您的方法的对象,然后从 IIFE 返回它,如下所示:

var MyNamespace = (function() {
    function myInternalMethod() {
        //Do whatever your function does here...
    }

    return {
        myPublicFunction() {
            return myInternalFunction();
        }
    }
})();

然后可以将您的回调设置为,MyNamespace.myPublicFunction因为 MyNamespace 将在全局范围内。

于 2015-08-10T08:15:00.977 回答