JS定时器

 window提供了如下4个方法来支持定时器。

setInterval("code" , interval)、clearlnterval (timer)设置、删除定时器。setInterval设置每隔interval毫秒重复执行一次code。
setTimeout("code",interval)、clearTimeout(timer)也是设置定时器。推荐使用setInterval()和clearInterval ()。 setTimeout 设置在interval 毫秒延迟后执行一 次
<!DOCTYPE html>
<html>
<head>
	<meta name="author" content="Yeeku.H.Lee(CrazyIt.org)" />
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
	<title> 使用定时器 </title>
</head>
<body onload="setTime();">
	<span id="tm"></span>
	<script type="text/javascript">
		// 定义定时器变量
		var timer;
		// 保存页面运行的起始时间
		var cur = new Date().getTime(); 
		var setTime = function()
		{
			// 在tm元素中显示当前时间
			document.getElementById("tm").innerHTML = 
				new Date().toLocaleString();
			// 如果当前时间比起始时间大于60秒,停止定时器的调度
			if (new Date().getTime() - cur > 60 * 1000)
			{
				// 清除timer定时器
				clearInterval(timer);
			}
		}
		// 指定每隔1000毫秒执行setTime()函数一次
		timer = setInterval("setTime();" , 1000);
	</script>
</body>
</html>

 

 

<!DOCTYPE html>
<html>
<head>
	<meta name="author" content="Yeeku.H.Lee(CrazyIt.org)" />
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
	<title> 使用定时器 </title>
</head>
<body>
	<span id="tm"></span>
	<script type="text/javascript">
		// 定义定时器变量
		var timer;
		// 保存页面运行的起始时间
		var cur = new Date().getTime(); 
		var setTime = function()
		{
			// 在tm元素中显示当前时间
			document.getElementById("tm").innerHTML
				= new Date().toLocaleString();
			// 如果当前时间比起始时间小于等于60秒,执行定时器的调度
			if (new Date().getTime() - cur <= 60 * 1000)
			{
				// 指定延迟1000毫秒后执行setTime()函数。
				window.setTimeout("setTime();" , 1000);
			}
		}
		// 直接调用setTime()函数
		setTime();
	</script>
</body>
</html>

 

### JavaScript 定时器 `setTimeout` 和 `setInterval` 的使用方法 JavaScript 提供了两种主要的定时器函数:`setTimeout` 和 `setInterval`,它们用于延迟执行或周期性地执行一段代码。 #### 1. `setTimeout` `setTimeout` 函数用于在指定的时间后执行一次回调函数。其基本语法如下: ```javascript setTimeout(function, delay, param1, param2, ...); ``` - **function**: 要执行的回调函数。 - **delay**: 延迟的时间(以毫秒为单位)。 - **param1, param2, ...**: 可选参数,传递给回调函数。 例如: ```javascript function Fun3(str1) { alert(str1); } var timer = setTimeout(Fun3, 2000, "参数1"); // 2秒后弹出“参数1” clearTimeout(timer); // 清除定时器,防止执行 ``` 上述代码展示了如何设置一个定时器并在两秒后执行回调函数[^1]。如果需要提前停止定时器,可以使用 `clearTimeout` 方法[^3]。 #### 2. `setInterval` `setInterval` 函数用于每隔指定的时间间隔重复执行回调函数。其基本语法如下: ```javascript setInterval(function, delay, param1, param2, ...); ``` - **function**: 要执行的回调函数。 - **delay**: 每次执行之间的间隔时间(以毫秒为单位)。 - **param1, param2, ...**: 可选参数,传递给回调函数。 例如: ```javascript var counter = 0; var intervalId = setInterval(function () { console.log("计数:", counter++); if (counter > 5) { clearInterval(intervalId); // 当计数超过5时停止定时器 } }, 1000); // 每隔1秒执行一次 ``` 上述代码展示了如何设置一个每秒执行一次的定时器,并在满足条件时通过 `clearInterval` 方法停止定时器[^2]。 #### 区别与注意事项 - **执行次数**:`setTimeout` 只执行一次,而 `setInterval` 会不断重复执行直到被清除。 - **清除方法**:`setTimeout` 使用 `clearTimeout`,`setInterval` 使用 `clearInterval`。 - **返回值**:两者都会返回一个唯一的标识符,用于清除对应的定时器。 ### 示例代码 以下是一个结合 `setTimeout` 和 `setInterval` 的完整示例: ```javascript // 使用setTimeout setTimeout(() => { console.log("这是setTimeout输出"); }, 3000); // 使用setInterval let count = 0; const intervalId = setInterval(() => { console.log("当前计数:", count++); if (count > 5) { clearInterval(intervalId); // 停止计时器 } }, 1000); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值