【html】颜色随机产生器(补充包)

news2024/11/13 8:10:31

上一篇文章我们讲了如何制作一个通过滑动产色纯色背景的网页,今天,我们对那个网页进行一个补充,()

因为很多人在设计网页的时候没有颜色的灵感这个时候我们我们就可以考虑通过随机产生一种颜色并且能够实时看到效果的网页 

我们来看看上次的代码:

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<!-- <meta name="viewport" content="width=device-width, initial-scale=1.0"> -->
		<title>调色盘</title>
		<style>
			#colorDisplay {
				width: 200px;
				height: 200px;
				margin: 20px;
			}
 
			body {
				background-color: #eee;
			}
		</style>
	</head>
	<body>
 
		<h2>调色盘</h2>
		<p>当前颜色: RGB(<span id="redValue">0</span>, <span id="greenValue">0</span>, <span id="blueValue">0</span>)</p>
		<label for="red">红色:</label>
		<input type="range" id="red" min="0" max="255" value="0" oninput="updateColor()">
 
		<label for="green">绿色:</label>
		<input type="range" id="green" min="0" max="255" value="0" oninput="updateColor()">
 
		<label for="blue">蓝色:</label>
		<input type="range" id="blue" min="0" max="255" value="0" oninput="updateColor()">
 
		<div id="colorDisplay" style="background-color: rgb(0, 0, 0);"></div>
 
		<script>
			function updateColor() {
				var red = document.getElementById('red').value;
				var green = document.getElementById('green').value;
				var blue = document.getElementById('blue').value;
				// 更新颜色值显示
				document.getElementById('redValue').textContent = red;
				document.getElementById('greenValue').textContent = green;
				document.getElementById('blueValue').textContent = blue;
				// 使用 rgb() 函数设置背景颜色
				var color = 'rgb(' + red + ',' + green + ',' + blue + ')';
				document.getElementById('colorDisplay').style.backgroundColor = color;
			}
 
 
			// 初始化颜色显示
			updateColor();
		</script>
 
	</body>
</html>

效果:

但是这里我们发现,只能自己去生成一种颜色,但是很多时候我们设计一个网页没有灵感并不想利用现有的预设颜色这个时候我们就可以通过随机产生颜色的方式。

我们可以考虑加一个随机产生的模块

<!DOCTYPE html>
<html lang="en">
	<head>
		<meta charset="UTF-8">
		<title>调色盘</title>
		<style>
			#colorDisplay {
				width: 300px;
				height: 300px;
				margin: 20px;
				border: 2px dashed #000;
				/* 添加边框 */
			}

			body {
				background-color: #eee;
				font-family: Arial, sans-serif;
				/* 统一的字体 */
			}
		</style>
	</head>
	<body>

		<h2>调色盘</h2>
		<p>当前颜色: RGB(<span id="redValue">0</span>, <span id="greenValue">0</span>, <span id="blueValue">0</span>)</p>
		<label for="red">红色:</label>
		<input type="range" id="red" min="0" max="255" value="0" oninput="updateColor()">

		<label for="green">绿色:</label>
		<input type="range" id="green" min="0" max="255" value="0" oninput="updateColor()">

		<label for="blue">蓝色:</label>
		<input type="range" id="blue" min="0" max="255" value="0" oninput="updateColor()">

		<button onclick="generateRandomColor()">生成随机颜色</button>

		<div id="colorDisplay" style="background-color: rgb(0, 0, 0);"></div>

		<script>
			function updateColor() {
				var red = document.getElementById('red').value;
				var green = document.getElementById('green').value;
				var blue = document.getElementById('blue').value;

				// 更新颜色值显示
				document.getElementById('redValue').textContent = red;
				document.getElementById('greenValue').textContent = green;
				document.getElementById('blueValue').textContent = blue;

				// 使用 rgb() 函数设置背景颜色
				var color = 'rgb(' + red + ',' + green + ',' + blue + ')';
				document.getElementById('colorDisplay').style.backgroundColor = color;


				// 获取当前颜色并更新边框颜色
				var color = 'rgb(' + red + ',' + green + ',' + blue + ')';
				updateBorderColor(color);
			}



			function updateBorderColor(color) {
				// 将RGB字符串转换为RGB数组
				var rgb = color.match(/\d+/g).map(Number);

				// 计算亮度(简单方法:R+G+B然后除以3)
				var brightness = (rgb[0] + rgb[1] + rgb[2]) / 3;

				// 根据亮度设置边框颜色
				var borderColor = brightness > 128 ? '#000' : '#fff'; // 亮度高于128用黑色,否则用白色
				document.getElementById('colorDisplay').style.borderColor = borderColor;
			}





			function generateRandomColor() {
				// 生成随机RGB颜色值
				var red = Math.floor(Math.random() * 256);
				var green = Math.floor(Math.random() * 256);
				var blue = Math.floor(Math.random() * 256);

				// 更新页面上的颜色值和显示
				document.getElementById('red').value = red;
				document.getElementById('green').value = green;
				document.getElementById('blue').value = blue;
				updateColor(); // 调用updateColor来更新显示
			}

			// 初始化颜色显示(可选,因为页面加载时已经是初始状态)
			// updateColor();
		</script>

	</body>
</html>

这样我们就多了一个功能

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2049321.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Delphi5实现密码、姓名生成器

文章目录 目的效果图密码生成器类类定义成员函数 点击“密码生成”事件名字生成器类类的成员功能概述注意点 点击“姓名生成”事件点击“清空”事件“导出txt”事件“备注”输入框画图软件完整代码 目的 写这个程序的目的是生成一个密码和用于快递的名字&#xff08;生成密码和…

keepalived详细讲解

keepalived&#xff1a; Keepalived是一个基于VRRP&#xff08;‌Virtual Router Redundancy Protocol&#xff0c;‌虚拟路由冗余协议&#xff09;‌协议实现的LVS&#xff08;‌Linux Virtual Server&#xff09;‌服务高可用方案。‌它的主要作用是进行虚拟路由的故障切换&…

算法打卡 Day24(二叉树)-二叉搜索树的最近公共祖先 + 二叉搜索树中的插入操作 + 删除二叉搜索树中的节点

文章目录 Leetcode 235-二叉搜索树的最近公共祖先题目描述解题思路 Leetcode 701-二叉搜索树中的插入操作题目描述解题思路 Leetcode 450-删除二叉搜索树中的节点题目描述解题思路 Leetcode 235-二叉搜索树的最近公共祖先 题目描述 https://leetcode.cn/problems/lowest-comm…

江协科技STM32学习笔记(第10章 SPI通信)

第10章 SPI通信 10.1 SPI通信协议 10.1.1 SPI通信 SPI&#xff08;Serial Peripheral Interface&#xff09;是由Motorola公司开发的一种通用数据总线&#xff1b; 串行外设接口&#xff1b; I2C无论是软件还是软件电路&#xff0c;设计的都还是比较复杂的&#xff0c;硬件…

xss靶场详解

目录 1.第一题 2.第二题 3.第三题 4.第四题 5.第五题 6.第六题 7.第七题 8.第八题 1.第一题 在源码script标签里边&#xff0c;innerhtml是用于访问或修改 HTML 元素内的 HTML 内容的&#xff0c;这里是访问spaghet这个元素的&#xff0c;并通过括号里面的东西搜索当前…

【问题解决3】【已解决】Cannot determine path to‘tools.jar‘libraryfor17

前几天在IDEA运行JAVA项目时&#xff0c;出现这个报错。 这是因为是这个笔记本上安装的IDEA版本是“IntelliJ IDEA 2020.3.1”&#xff0c;与JDK17版本不兼容&#xff0c;这种情况下要想使得IDEA版本与JDK版本兼容&#xff0c;就需要升级IDEA版本或者使用JDK较低版本&#xff…

专题---自底向上的计算机网络(计算机网络相关概述)

目录 计算机网络相关概述 物理层 数据链路层 网络层 运输层 应用层 网络安全 1.计算机网络相关概述&#xff08;具体细节http://t.csdnimg.cn/NITAW&#xff09; 什么是计算机网络&#xff1f; 计算机网络是将一个分散的&#xff0c;具有独立功能的计算机系统&#x…

FusionSphere虚拟机网络不通

虚拟机侧 1、通过控制台Console或者VNC登录虚拟机。 获取VNC的token链接&#xff0c;因为token有超时失效&#xff0c;该链接获取后长时间不用要重新获取。 # nova get-vnc-console vmid novnc 2、登录VNC控制台之后&#xff0c;检查网卡和IP地址是否up, ARP学习是否正常…

Postman 问题汇总

1 postman Error: SSL Error: UNABLE_TO_VERIFY_LEAF_SIGNATURE 根因 SSL校验失败&#xff0c;可以在postman设置中关闭ssl校验&#xff0c;自测对ssl无要求。 解决方法 在postman设置中关闭ssl校验&#xff1a;

树莓派智能语音助手之聊天机器人-RASA

我的树莓派目前已经会“说”&#xff08;《树莓派智能语音助手之TTS - pyttsx3 espeak》&#xff09;&#xff0c;也能“听”&#xff08;《树莓派智能语音助手之ASR2 – sherpa-ncnn》&#xff09;了。接下来&#xff0c;就要让它能够和我们对话起来&#xff0c;即会“聊天”…

python 获取pdf文件中的超链接

pip install pymupdf pip install fitzimport fitz # PyMuPDFdef get_pdf_links(pdf_path):# 打开PDF文件document fitz.open(pdf_path)links []for page_num in range(len(document)):page document[page_num]# 获取当前页面的链接for link in page.get_links():links.app…

Mac升级系统文件都丢了怎么办?Mac更新后资料找不到了怎么恢复

Mac电脑由于其卓越的性能&#xff0c;受到了众多电脑用户的青睐。为了让用户获得更好的使用体验&#xff0c;Mac系统会定期推出新版本&#xff0c;来弥补前一个版本的不足。然而有用户反馈&#xff0c;Mac升级后&#xff0c;电脑里的部分资料消失了。mac升级会丢失文件吗?mac升…

iOS ColleCtionView 如何让cell 不重复创建并且只在展示的时候才创建

前言 使用 collectionView 一屏只展示一个 cell &#xff0c;一次只加载当前 cell&#xff0c;还要能够缓存已加载过的 cell &#xff0c;使 cell 不重复加载&#xff0c;听着好像就是将 collectionView 的复用机制禁用掉。用collectionView 实现这个需求&#xff0c;就出现了…

【GD32】从零开始学GD32单片机 | PMU电源管理单元+深度睡眠和待机例程(GD32F470ZGT6)

1. 简介 PMU电源管理单元通俗讲就是用来管理MCU的电源域的&#xff0c;它主要有两个功能——电压监测和低功耗管理。在GD32中一共有3个电源域——VDD/VDDA域、1.2V域和备份域。 VDD/VDDA域主要供PMU控制器、ADC、DAC等外设使用&#xff1b;1.2V域就是大部分外设都会使用的电源域…

ai大模型之争-生成音乐-豆包

豆包网页版&#xff1a;豆包 可以生成自定义音乐了 1&#xff0c;打开网页&#xff0c;登录 2&#xff0c;选择音乐生成 3&#xff0c;进行音乐配置 3.1&#xff0c;可以选择&#xff1a; 1&#xff0c;自己写歌词或者ai创造歌词&#xff1b; 2&#xff0c;可以选输入歌词…

xss漏洞复现

目录 第一关 第二关 第三关 第四关 第五关 第一关 要求&#xff1a; Pop an alert(1337) on sandbox.pwnfunction.com. No user interaction. 代码&#xff1a; <!-- Challenge --> <h2 id"spaghet"></h2> <script> spaghet.inn…

【数据结构与算法 | 图篇】Floyd-Warshall算法(多源最短路径算法)

1. 前言 Floyd-Warshall算法是一种在有向图或无向图中寻找所有顶点对之间的最短路径的动态规划算法。该算法可以处理带权重的边&#xff0c;并且能够正确处理负权重的边&#xff08;但不包括负权重循环&#xff09;&#xff0c;不过它不能处理包含负权重循环的情况&#xff0c…

IDEA 设置SVN项目管理忽略文件

忽略已经控制的文件 打开本地已经克隆下来的项目&#xff0c;并找到需要忽略控制的文件或文件夹 操作完成之后需要将当前的操作更新到SVN服务器。 直接在IDEA中提交修改&#xff08;快捷键CTRL K&#xff09;就可以 unverison: 取消版本控制 add to ignore list&#xff1…

C语言之文件操作上卷(二十一)(逆行人生-2024)

&#x1f4e3;&#x1f4e3;&#x1f4e3;&#x1f4e3;&#x1f4e3;&#x1f4e3;&#x1f4e3;&#x1f4e3; ✏️作者主页&#xff1a;枫霜剑客 &#x1f4cb; 系列专栏&#xff1a;C语言知识学习归纳总结&#xff08;逐梦篇专栏合集&#xff09; &#x1f332;上一篇: C语…