您尚未登录,请登录后浏览更多内容! 登录 | 立即注册

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 11092|回复: 0
打印 上一主题 下一主题

[js学习资料] js定时器(执行一次、重复执行)

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-31 10:57:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
1,只执行一次的定时器
( e- p+ k/ Z+ `4 m7 A8 Q5 Y
  1. <script>
    % g& T) _6 c. ]/ z5 W$ p
  2. //定时器 异步运行 5 x) W- Z/ S# y- O
  3. function hello(){
    . }' c: ~( B$ v- l' v9 O2 z
  4. alert("hello"); 4 e/ d2 z; Z6 o- M, v' N$ j/ q% w! r# q& v
  5. }
    : @: r( o- G7 o  t: h% r
  6. //使用方法名字执行方法 5 c1 d, s! F3 G+ K! x& c; n7 m4 Q
  7. var t1 = window.setTimeout(hello,1000); ( P8 A1 T$ q% `+ A8 x
  8. var t2 = window.setTimeout("hello()",3000);//使用字符串执行方法
    # B! n- M2 [7 s7 K
  9. window.clearTimeout(t1);//去掉定时器 ( ?% {. M' t0 ~
  10. </script>
复制代码
2,重复执行的定时器
7 ~' u, C, g# n% s
  1. <script>
    / e! {; S2 p% B, L
  2. function hello(){ ' @5 m5 t, m  F! P2 a* f
  3. alert("hello"); 7 d/ E0 U1 g0 K$ r
  4. }
    * {5 C$ Z! U! w
  5. //重复执行某个方法 . m, Q8 e2 o' |- H6 x2 u
  6. var t1 = window.setInterval(hello,1000); 8 w' i: _1 d3 ^9 z( J0 S5 e6 u
  7. var t2 = window.setInterval("hello()",3000);
    0 T! q6 q6 u- E3 T3 E% a
  8. //去掉定时器的方法
    8 @2 N, R8 R, v2 k: ]
  9. window.clearInterval(t1);
    ) ^! s& t* V7 d2 P4 U' Z
  10. </script>
复制代码
备注:
' h8 g. V! Y8 d+ ]5 p! @- q# k) d7 b) P; X' ~8 n2 O
如果在一个页面中有两个方法,都是在页面加载完成之后执行的,实际却未能按先后顺序执行,可以参照如下方法解决:
' P; I( A% T0 d3 f! R可以在onload方法中添加一个定时器,设置一个定时器,“延迟”一段时间之后再运行,即可认为区分页面加载运行方法的先后顺序。8 e( l% ^8 d% G$ A
4 Y+ w: o) {! U; S

在javascritp中,有两个关于定时器的专用函数,分别为:

1.倒计定时器:timename=setTimeout("function();",delaytime);6 a' C' k7 T" |/ h4 _" m
2.循环定时器:timename=setInterval("function();",delaytime);

第一个参数“function()”是定时器触发时要执行的动作,可以是一个函数,也可以是几个函数,函数间用“;”隔开即可。比如要弹出两个警告窗口,便可将“function();”换成
1 _- b5 E& }! M# ~( r) }& v0 \“alert('第一个警告窗口!');alert('第二个警告窗口!');”;而第二个参数“delaytime”则是间隔的时间,以毫秒为单位,即填写“5000”,就表示5秒钟。
( B$ r/ \% k. h6 g9 y; s  倒计时定时器是在指定时间到达后触发事件,而循环定时器就是在间隔时间到来时反复触发事件,两者的区别在于:前者只是作用一次,而后者则不停地作用。
! V/ u2 T4 ]& t8 C比如你打开一个页面后,想间隔几秒自动跳转到另一个页面,则你就需要采用倒计定时器“setTimeout("function();",delaytime)” ,而如果想将某一句话设置成一个一个字的出现,0 k  y" c( b9 k8 S3 T* o, ~
则需要用到循环定时器“setInterval("function();",delaytime)” 。

获取表单的焦点,则用到document.activeElement.id。利用if来判断document.activeElement.id和表单的ID是否相同。
( u& |- O5 m" J" C% W. L% \. V比如:if ("mid" == document.activeElement.id) {alert();},"mid"便是表单对应的ID。

定时器:

用以指定在一段特定的时间后执行某段程序。

JS中定时执行,setTimeout和setInterval的区别,以及l解除方法

setTimeout(Expression,DelayTime),在DelayTime过后,将执行一次Expression,setTimeout 运用在延迟一段时间,再进行某项操作。& Y+ a; D  `1 R% ]8 F- [9 V& l
setTimeout("function",time) 设置一个超时对象

setInterval(expression,delayTime),每个DelayTime,都将执行Expression.常常可用于刷新表达式./ R7 R9 w+ ]- j) ]$ q5 J, K+ v
setInterval("function",time) 设置一个超时对象

SetInterval为自动重复,setTimeout不会重复。

clearTimeout(对象) 清除已设置的setTimeout对象
, O1 _4 a2 m' x0 H6 Y) H1 kclearInterval(对象) 清除已设置的setInterval对象

略举两例。
* C) S; \7 A! ~, S8 c5 c5 D$ J( u例1.表单触发或加载时,逐字输出字符串

* G4 d3 o. w+ n5 T
  1. <html>- K, ^4 h1 V0 i) a+ b
  2. <head>6 w" k" Z2 ~* x4 C0 D* k, t
  3. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />, O: A" C& k: H  k, d$ K
  4. <title>无标题文档</title>
    $ [! I7 I3 l) ^2 _
  5. <script language="JavaScript" type="text/javascript">% q6 c2 t* \% ~; t9 ~: z
  6. var str = "这个是测试用的范例文字";6 e6 t$ V) x% f# G' _
  7. var seq = 0;
    9 @! B7 i4 x5 L* |
  8. var second=1000; //间隔时间1秒钟
    & h" w9 Z+ @9 q# R; k* P/ I
  9. function scroll() {
    1 m& u$ {' ~: F
  10. msg = str.substring(0, seq+1);
    ) l" U& f: O, ?. x2 q
  11. document.getElementByIdx_x_x('word').innerHTML = msg;
    * ~3 {/ y6 M8 \6 K" F: v
  12. seq++;
    2 `# [7 p: @( A! q4 ]
  13. if (seq >= str.length) seq = 0;
    * R9 W. j5 x$ i$ {/ {
  14. }+ e) Z, m5 ^7 Y, W7 S5 E
  15. </script>: A* U* f5 M  z
  16. </head>$ d  r" E' l8 c& D& _9 J
  17. <body onload="setInterval('scroll()',second)">
    3 o' [; S3 M4 e' _9 d' G; P
  18. <div id="word"></div><br/><br/>% m( d* o/ ?3 G# r2 i# y8 J
  19. </body>) d0 {' b1 P$ D- t
  20. </html>
复制代码
例2.当焦点在输入框的时候,定时检查输入框信息,焦点不在时不执行检查动作。
3 I  L3 u$ A" H( w# [( b8 M/ o
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">- ]$ S. i/ T3 c3 {% O. B0 Y* P4 X8 ?
  2. <html xmlns="http://www.w3.org/1999/xhtml">+ P3 d2 y7 ~; a2 |& r
  3. <head>
    8 v- U! a2 O. E! m5 X. E  E, Q
  4. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    # A" t8 i( g5 K& Y& M8 A
  5. <title>无标题文档</title>
    % [$ ~5 u8 `  g* s5 ]
  6. <script language="JavaScript" type="text/javascript">' x# a/ w- w+ B9 L+ d) Z
  7. var second=5000; //间隔时间5秒钟8 Z, _$ B. k! g' c
  8. var c=0;
    ' w- k* J' i1 w* T4 n5 J- W+ P) m
  9. function scroll() {
    : Y9 M) ?# ?$ U4 p9 h' J9 V
  10. c++;- A0 P' j+ c0 i( Q# X% I+ H
  11. if ("b" == document.activeElement.id) {9 D2 u. s2 v& X% _* g
  12. var str="定时检查第<b> "+c+" </b>次<br/>";
    5 a! V6 I1 j  w2 b# ]) r( {
  13. if(document.getElementByIdx_x_x('b').value!=""){: U0 i2 N! O8 f5 D) S5 E
  14. str+="输入框当前内容为当前内容为<br/><b> "+document.getElementByIdx_x_x('b').value+"</b>";
    , R( y( K/ B8 \8 }; W  L
  15. }
    7 [& H- D0 f( ?( y1 t
  16. document.getElementByIdx_x_x('word').innerHTML = str;
    6 }) z+ o: g! n
  17. }: I- L3 G; D5 z6 I: V
  18. }% M4 w, q2 s4 `" M/ X; X, S; z, I
  19. </script>
    ! l& A( H6 Z! p
  20. </head>, N3 q. {3 d$ {$ y
  21. <body>
    $ t. C' Z3 x% Q
  22. <textarea id="b" name="b" style="height:100px; width:300px;" onfocus="setInterval('scroll()',second)"></textarea><br/><br/>
    ( `# C# N8 m% k( w* w% f
  23. <div id="word"></div><br/><br/>
    $ E/ t% O) U7 o: [6 j) ?1 B
  24. </body>
    6 s) V8 W3 Q8 h
  25. </html>
复制代码
例3.下面这个是最简单的例子,定时器时间到达后弹出警告窗口。( s( |# I5 ]- }1 [
  1. <html xmlns="http://www.w3.org/1999/xhtml">
    ) [7 D7 ?3 [6 G: B
  2. <head>7 w5 b1 R* e$ a$ u; Y
  3. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    * V) g9 a; y" g- ~# S7 E6 G! F) I- m
  4. <script language="javascript">
    $ z$ ~6 ~& m; v2 ^" F* q
  5. function count() {' N" {" ]+ f- M2 u  K
  6. document.getElementByIdx_x_x('m').innerHTML="计时已经开始!";' c: z. C7 o# b0 b
  7. setTimeout("alert('十秒钟到!')",10000)
    ' h- T: E. X3 n: T
  8. }
    ) ^+ Y( r! v+ n* r- P* P' W
  9. </script>. J6 t, }' z# K; G, e
  10. <body>- p+ Q2 \. h; ~5 a! e
  11. <div id="m"></div>
    # b1 R6 U! X+ K/ e0 O5 N
  12. <input TYPE="button" value=" 计时开始" onclick="count()">0 m3 r4 ^* l1 ]) N3 j
  13. </body>( C- D& D8 A& N: q
  14. </html>
复制代码
例4:倒计时定时跳转
' p* G8 D2 W/ U* q2 q( a# \! m
  1. <html>' m4 `& N1 {# T% H0 f! R
  2. <head>
    4 v4 D, v2 B- n. j+ H' L2 O
  3.   <base href="<%=basePath%>">
    ) f1 t  _% Q; c" d5 A- b4 C( |' ~
  4.   <title>My JSP 'ds04.jsp' starting page</title>
    ! x# n" h9 W4 I" Z- ]
  5.   <span id="tiao">3</span>
    9 G4 ~& ~, y# b( E# W
  6.   <a href="javascript:countDown"> </a>秒后自动跳转……" E" ~( \3 J  }% W" q
  7.   <meta http-equiv=refresh content=3;url= '/ds02.jsp'/>
    / G- O* _2 l1 ^6 t7 l
  8.   <!--脚本开始-->
    - p+ l  Q; G$ u# f
  9.   <script language="javascript" type="">
    & h! ?1 A6 V" p9 D: W' ^
  10. function countDown(secs){
    3 A  `: X; i2 m* W- T+ h
  11. tiao.innerText=secs;
      |+ w2 ^/ {# V
  12. if(--secs>0)- ^$ e* k2 [4 V, J, g8 S. j7 b7 c
  13.   setTimeout("countDown("+secs+")",1000);
    4 {( ?  h$ C0 }$ j+ k8 s5 u
  14. }
    . L" S3 Y* d8 U' N: o0 L3 y
  15. countDown(3);
    ( a  F) q* \0 j/ T
  16. </script>
    0 A, ^  h" k! u( V; m5 u  C
  17.   <!--脚本结束-->& Q9 _" O  P4 V: C
  18. </head>
复制代码
例6:
  B+ t, n# \! m+ w' ^1 T% u
  1. <head> ! V6 k: G5 l( R5 h
  2.     <meta http-equiv="refresh" content="2;url='b.html'">
    ( n7 f% `4 c# m3 X5 U8 A: F
  3. </head>
复制代码
例7:
; i0 E; e) I5 \1 V4 Y; g) o2 E: l
  1. <script language="javascript" type="text/javascript">
    . [' X/ f6 T  E; D9 G0 N2 c
  2. setTimeout("window.location.href='b.html'", 2000);0 ~, _( w: W4 E) S' ]& \
  3. //下面两个都可以用
    $ f% `2 j7 `" R
  4. //setTimeout("javascript:location.href='b.html'", 2000);
    " K6 ~' P) T2 f. X
  5. //setTimeout("window.location='b.html'", 2000);: U+ L+ z4 A2 T, o$ |% p
  6. </script>
复制代码
例8:5 g# I0 Z2 {) Z2 L
  1. <span id="totalSecond">2</span>
    ' K2 K) F: e( P2 Q/ \/ i
  2. <script language="javascript" type="text/javascript">
      [# G' K7 Q: K# ]
  3. var second = document.getElementByIdx_x('totalSecond').innerHTML;7 c! m6 O% R+ _) L
  4. if(isNaN(second)){
    / l# U# z' Q; C) p6 A' h  D: m; k
  5.   //……不是数字的处理方法0 E8 A. H& G1 C
  6. }else{5 x7 l" V) _5 b) E# [6 ?/ G; z
  7.   setInterval(function(){- U& O, _; ~) o$ |6 S. {( N
  8.    document.getElementByIdx_x('totalSecond').innerHTML = --second;
    7 O- a& |# C7 `+ C
  9.    if (second <= 0) {8 [! d; I1 u* s' C
  10.     window.location = 'b.html';
    2 e: m; V" V) E- D7 m# n+ a
  11.    }  c; L3 C; N  \  v: E: {1 p
  12.   }, 1000);
    ! u# r+ n% \$ Q* b$ j
  13. }
    & Q( V" p3 \. ~2 ^
  14. </script>
复制代码
$ Y- F% F- `* H/ J; X
: E, h; w) w9 ^% U8 X. u+ w( }3 J
$ J& P/ }* H8 U& @
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-23 01:43 , Processed in 0.112477 second(s), 22 queries .

Copyright © 2001-2024 Powered by cncml! X3.2. Theme By cncml!