Как получить имя экземпляра объекта
-
20-09-2019 - |
Вопрос
Я использую приведенный ниже код, чтобы написать код для запроса веб-метода с заданным интервалом.
теперь в функции 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();
});