div 随机位置、颜色、大小

本文介绍了一个使用HTML、CSS和JavaScript实现的互动效果,当用户点击页面时,一个盒子会随机改变其颜色和位置,同时调整其大小。通过Math.random()函数生成随机数,实现了div元素的随机变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>随机颜色</title>
		<style type="text/css">
			#app{
				position: absolute;
			}
		</style>
	</head>
	<body>
		<div id="app">
			盒子
		</div>
	</body>
	<script type="text/javascript">
		init();
		function init() {
			document.addEventListener("click", click);	//监听 点击事件		
			appRandom(); //随机一次
		}
		// 点击事件
		function click(e){
			e=e || window.event
			appRandom()
		}
		//位置随机
		function appRandom(){
			var apps = document.getElementById("app"); 
			var seat = seatSize(); //seat作为位置大小的数据暂存
			cloneObj(apps.style, {
				left: seat.left + "px",
				top: seat.top + "px",
				width: seat.width + "px",
				height: seat.height + "px",
				backgroundColor:appColor()
			})
		}
		//克隆对象属性
		function cloneObj(biaoji, Square) {
			for (var key in Square) {
				biaoji[key] = Square[key];
			}
		}
		//div大小&位置 随机的变化函数
		function seatSize() {
			var w = Math.random() * document.documentElement.clientWidth;
			var h = Math.random() * document.documentElement.clientHeight;
			var x = Math.random() * (document.documentElement.clientWidth - w);
			var y = Math.random() * (document.documentElement.clientHeight - h);
			return {
				left: x,
				top: y,
				width: w,
				height: h
			};
		}
		//随机颜色
		function appColor(){
			var co = "#"; //字符串第一位为# 颜色的格式
			for (let i = 0 ; i < 3; ++i){
			co += parseInt(Math.random() * 256).toString(16)
			}
			return co
		}
	</script>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值