结合Html、Javascript、Jquery做个简易的时间显示器

**前提:**先将jquery文件引入

下载地址:jQuery

html 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>我的计时器</title>
	</head>
	<body>
		<p id="p1">这是一个计时器</p>
		<div id="timeDisplay"></div>
		<button id="btn1" type="button">开始计时</button>
		<button id="btn2" type="button">计时暂停</button>
		<button id="btn3" type="button">计时清零</button>
	</body>
	<script src="js/jquery-3.4.1.js" type="text/javascript" charset="utf-8"></script>
	<script type="text/javascript">
		var time = null;
		
		$("#btn1").bind("click",function(){
			/* 
			防止定时器资源重复累积
			   先检查变量time是否有值(即是否已经存在一个定时器)。
			   如果有,则清除现有的定时器(clearInterval(time)),然后再设置新的定时
			   这样做的目的是为了避免同时运行多个定时器(如果用户多次点击btn1,会导致多个定时器同时运行,
			   从而造成时间显示更新频率加快,甚至内存泄漏)
			 */
			if(time){
				clearInterval(time);
			}
			
			time = setInterval(function() {
				var date = new Date();
				$("#timeDisplay").text("当前时间是:"+date.toLocaleString());
			}, 1000);
		});
		$("#btn2").on("click",function(){
			clearInterval(time);
			/* 如果我们不将time置为null,那么再次点击btn1时,if(time)就会判断为true
			(因为time是一个非null的值,即使这个定时器已经被清除),然后执行clearInterval */
			time = null;
		})
		$("#btn3").on("click",function(){
			clearInterval(time);
			time = null;
			$("#timeDisplay").text("");
		})
		
	</script>
</html>
相关推荐
烬头882130 分钟前
React Native鸿蒙跨平台采用了函数式组件的形式,通过 props 接收分类数据,使用 TouchableOpacity实现了点击交互效果
javascript·react native·react.js·ecmascript·交互·harmonyos
Amumu1213830 分钟前
Vuex介绍
前端·javascript·vue.js
2601_9498095943 分钟前
flutter_for_openharmony家庭相册app实战+相册详情实现
javascript·flutter·ajax
qq_177767371 小时前
React Native鸿蒙跨平台通过Animated.Value.interpolate实现滚动距离到动画属性的映射
javascript·react native·react.js·harmonyos
2601_949833391 小时前
flutter_for_openharmony口腔护理app实战+饮食记录实现
android·javascript·flutter
2601_949480061 小时前
【无标题】
开发语言·前端·javascript
css趣多多1 小时前
Vue过滤器
前端·javascript·vue.js
●VON2 小时前
React Native for OpenHarmony:项目目录结构与跨平台构建流程详解
javascript·学习·react native·react.js·架构·跨平台·von
爱吃大芒果2 小时前
Flutter for OpenHarmony 实战:mango_shop 路由系统的配置与页面跳转逻辑
开发语言·javascript·flutter
qq_177767372 小时前
React Native鸿蒙跨平台实现消息列表用于存储所有消息数据,筛选状态用于控制消息筛选结果
javascript·react native·react.js·ecmascript·harmonyos