Вопрос

Я использую приведенный ниже код, чтобы написать код для запроса веб-метода с заданным интервалом.

теперь в функции this.Poll я должен выполнить

this.tmo = setTimeout(this.strInstanceName + ".Poll()", this.iInterval);

вместо того, чтобы

this.tmo = setTimeout(this.Poll(), this.iInterval);

потому что IE теряет указатель this после setTimeout
Итак, я должен передать классу имя его экземпляра:

    var objPoll = new cPoll("objPoll");


Как я могу получить имя экземпляра, не передавая его в качестве параметра?
Я хочу вытащить это оттуда !

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title>Intervall-Test</title>
    <script type="text/javascript" language="javascript">


        function test()
        {
            alert("Test");
            test.tmo = setTimeout(test, 2000);

            test.Clear = function()
            {
                clearTimeout(test.tmo);
            }
        }




        function cPoll(strInstanceName)
        {
            this.strInstanceName = strInstanceName ;
            this.iInterval = 2000;
            this.tmo=null;
            this.cbFunction=null;

            this.Poll = function()
            {
                this.cbFunction();
                this.tmo = setTimeout(this.strInstanceName + ".Poll()", this.iInterval);
            }

            this.Start = function(pCallBackFunction, iIntervalParameter)
            {


                if(this.tmo != null)
                    this.Stop();

                if(iIntervalParameter && iIntervalParameter > 0)
                    this.iInterval=iIntervalParameter;

                this.cbFunction=pCallBackFunction;
                if(this.cbFunction!=null)
                    this.Poll();
                else
                    alert("Invalid or no callback function specified");
            }

            this.Stop = function()
            {
                if(this.tmo != null)
                {
                    clearTimeout(this.tmo);
                    this.tmo=null;
                }
            }
        }


        function CallBackFunction()
        {
            alert("PollCallBack");
        }

        // test();
        // test.Clear();


        var objPoll = new cPoll("objPoll");
    </script>
</head>

<body>
<h1>Test</h1>

<input type="Button" value="Start polling" onclick="objPoll.Start(CallBackFunction,3000);" />
<input type="Button" value="Stop polling" onclick="objPoll.Stop();" />
</body>
</html>
Это было полезно?

Решение 7

Я задал еще вопрос, ответ здесь:

JavaScript:Список глобальных переменных в IE

Перебираем глобальные переменные и проверяем, равны ли они «этому».

Другие советы

Раскройте скобки в this.Poll().Вы вызываете эту функцию сразу, а не через какой-то промежуток времени.Если вы раскроете скобки, в функцию будет передана функция, а не ее результат. setInterval и у вас не будет никаких проблем.

setTimeout(this.Poll, this.Interval);

В противном случае вы сразу вызываете функцию, и ничего не происходит. this указателя больше нет, и IE просто удаляет его.

В фиксированном варианте this.Poll будет содержать указатель на this и оно не будет удалено.

Я просто хотел сказать, что этот трюк с самим собой спас меня от тонна о выдергивании волос.

Я не думал создавать подобную ссылку.Это означает, что динамически создаваемые элементы с событиями on click могут вызывать правильный экземпляр моего класса.

Вы также можете использовать:

то есть

var name = findInstanceOf(cPoll);

function findInstanceOf(obj) {
    for (var v in window) {
        try {
            if (window[v] instanceof obj)
                return v;
        } catch(e) { }
    };
    return false;
}

От http://www.liam-galvin.co.uk/2010/11/24/javascript-find-instance-name-of-an-object/#read

var self = this;
this.tmo = setTimeout(function(){
     self.Poll();
}, this.iInterval);

Сегодня я дал ответ на аналогичный вопрос, в котором создал класс опроса с нуля.Возможно, вы захотите перенять его для себя.Чтобы не дублировать, вот ссылка на указанный вопрос:

Опрос сервера с помощью Ajax и Dojo *

* Несмотря на название, мое решение предлагает как «ванильный», так и стиль Dojo.

Вы можете использовать эту удобную небольшую оболочку для периодического выполнения функции с заданным интервалом (по умолчанию 1 секунда):

function tick(func, interval) {
    return (function() {
        if(func())
            setTimeout(arguments.callee, interval || 1000);
    })();
}

Функция повторяется до тех пор, пока не вернет false:

tick(function() {
   if(should stop) return false;
   do stuff
   return true;
});

Если функция является методом, сделайте замыкание, как показано.

// inside your object
var me = this;
tick(function() {
   return me.doStuff();
});
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top