JavaScript « остановка таймера при переключение на другую вкладку браузера
у меня к вам еще один вопрос
Имею вот данный жаваскрипт, суть его работы в том что если выходишь со страницы то есть переключаешся в другую вкладку браузера то он остонавливает таймер
что мне надо ?
1)у него есть минус, если в этой же странице кликнуть где нибуть, то таймер остонавливается
вот как сделать что бы он не остонавливался если кликаешь где нибуть в странице.
сделать так что бы он остонавливал таймер толька при переключение вкладки браузера
2)если переключался на другой вкладке и когда вернулся таймер стойт,
вот можно ли как нибуть создать кнопочьку и при её нажатие таймер пощел дальше
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
Имею вот данный жаваскрипт, суть его работы в том что если выходишь со страницы то есть переключаешся в другую вкладку браузера то он остонавливает таймер
что мне надо ?
1)у него есть минус, если в этой же странице кликнуть где нибуть, то таймер остонавливается
вот как сделать что бы он не остонавливался если кликаешь где нибуть в странице.
сделать так что бы он остонавливал таймер толька при переключение вкладки браузера
2)если переключался на другой вкладке и когда вернулся таймер стойт,
вот можно ли как нибуть создать кнопочьку и при её нажатие таймер пощел дальше
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
<script type="text/javascript">
var b = false;
var last = 0;
function t() {
var c = document.getElementById('time');
if (typeof c == "undefined") return;
var t = parseInt(c.innerHTML);
last = stime();
if (t > 0) {
if (b == true) {
setTimeout('t()', 1000);
return
}--t;
setTimeout('t()', 1000)
} else {
document.getElementById('apar').style.display = '';
document.getElementById('time').style.display = 'none';
}
c.innerHTML = t
};
function stime() {
var d = new Date();
return d.getTime()
};
function w_obj() {
var wobj, i;
for (i = 0; i < 10; ++i) {
wobj = self.parent;
if ((wobj && !(wobj === self)) && (wobj.frames.length != 0)) {
wobj = self.parent
}
}
return wobj
}
var w;
if (navigator.appName == "Microsoft Internet Explorer") w = w_obj();
else w = top;
setTimeout('t()', 1000);
w.onblur = function() {
b = true
};
w.onfocus = function() {
b = false
};
w.onmousemove = function() {
b = false;
if (last > 0 && last < stime() - 1500) setTimeout('t()', 1000)
};
</script>
var b = false;
var last = 0;
function t() {
var c = document.getElementById('time');
if (typeof c == "undefined") return;
var t = parseInt(c.innerHTML);
last = stime();
if (t > 0) {
if (b == true) {
setTimeout('t()', 1000);
return
}--t;
setTimeout('t()', 1000)
} else {
document.getElementById('apar').style.display = '';
document.getElementById('time').style.display = 'none';
}
c.innerHTML = t
};
function stime() {
var d = new Date();
return d.getTime()
};
function w_obj() {
var wobj, i;
for (i = 0; i < 10; ++i) {
wobj = self.parent;
if ((wobj && !(wobj === self)) && (wobj.frames.length != 0)) {
wobj = self.parent
}
}
return wobj
}
var w;
if (navigator.appName == "Microsoft Internet Explorer") w = w_obj();
else w = top;
setTimeout('t()', 1000);
w.onblur = function() {
b = true
};
w.onfocus = function() {
b = false
};
w.onmousemove = function() {
b = false;
if (last > 0 && last < stime() - 1500) setTimeout('t()', 1000)
};
</script>
1 ответов
Не задавался такой задачей, но в качестве идеи - а если в самом таймере проверять видимость, какого-нибудь элемента на странице?