如何使用 HTML、CSS 和 JavaScript 随机更改图片颜色

news2025/6/9 5:01:36

原文:如何使用 HTML、CSS 和 JavaScript 随机更改图片颜色 | w3cschool笔记

(请勿标记为付费!!!!)

在网页开发中,为图片添加动态效果可以显著提升用户体验。今天,我将向大家介绍如何通过 HTML、CSS 和 JavaScript 实现图片颜色的随机更改。这个教程不仅简单易懂,还能帮助你理解前端开发中的交互式设计原理。

方法一:使用 Math.random() 函数

示例代码

<!DOCTYPE html>
<html>
<head>
    <title>随机更改图片颜色 | 编程狮(w3cschool.cn)</title>
    <style>
        body {
            overflow: hidden; /* 隐藏溢出内容 */
        }
        #container {
            top: 0;
            width: 350px;
            height: 150px;
            position: absolute; /* 绝对定位 */
            mix-blend-mode: hue; /* 颜色混合模式 */
        }
        img {
            width: 200px;
            height: auto; /* 自动调整高度,保持宽高比 */
        }
        p {
            font-size: 20px;
            font-weight: bold;
            margin-left: 15px;
        }
    </style>
</head>
<body>
    <img src="https://atts.w3cschool.cn/images%2Fw3c%2F20220506-154940.png" alt="示例图片"> 
    <div id="container"></div>
    <p>点击图片更改颜色</p>
    <script>
        const divElement = document.getElementById("container"); // 获取容器元素
        function selectcolor() {
            return Math.floor(Math.random() * 255); // 生成 0 到 255 之间的随机整数
        }
        divElement.addEventListener('click', () => { // 添加点击事件监听器
            divElement.style.backgroundColor = 'rgba('
                + selectcolor() + ',' + selectcolor() // 设置随机背景颜色
                + ',' + selectcolor() + ')';
        });
    </script>
</body>
</html>

将代码复制至 > HTML在线编译器查看效果

代码解析

  1. HTML 部分
    • 使用 <img> 标签引入图片,并设置相应的 src 属性。
    • 创建一个 <div> 容器,用于应用颜色变化效果。

  1. CSS 部分
    • 为 body 设置 overflow: hidden,以隐藏可能溢出的内容。
    • 为 #container 设置绝对定位和尺寸,并应用 mix-blend-mode: hue 以实现颜色混合效果。

  1. JavaScript 部分
    • 使用 Math.random() 生成随机数,并通过 Math.floor() 将其转换为整数。
    • 为容器添加点击事件监听器,点击时随机更改背景颜色。

方法二:使用十六进制颜色代码

示例代码

<!DOCTYPE html>
<html>
    <head>
        <title>随机更改图片颜色 | 编程狮(w3cschool.cn)</title>
        <style>
            body {
                background-color: paleturquoise; /* 设置背景颜色 */
            }
            .container {
                width: 75%;
                height: 100vh;
                display: flex;
                justify-content: center;
                align-items: center;
                text-align: center;
                margin: auto;
            }
            h3 {
                font-size: 18px;
                margin: 10px 20px 20px 10px;
                color: white;
            }
            .btn1 {
                padding: 2% 2%;
                border: none;
                border-radius: 4px;
                color: teal;
                font-size: 15px;
                cursor: pointer;
            }
            img {
                max-width: 100%; /* 图片最大宽度为容器宽度 */
                height: auto; /* 自动调整高度,保持宽高比 */
                border: 2px solid white; /* 添加边框 */
            }
            p {
                animation: hexcolors 5s infinite alternate; /* 添加动画效果 */
                font-size: 20px;
                font-weight: bold;
                color: navy;
            }
            @keyframes hexcolors { /* 定义动画关键帧 */
                0% { color: violet; }
                20% { color: indigo; }
                40% { color: blue; }
                60% { color: green; }
                80% { color: yellow; }
                100% { color: orangered; }
            }
            @media screen and (min-width: 992px) { /* 响应式设计 */
                .container { width: 100vw; margin: auto; }
                h2 { font-size: 30px; }
                .btn1 { padding: 2% 2%; margin: auto; font-size: 20px; font-weight: bold; }
            }
        </style>
    </head>
    <body>
        <div class="container">
            <div>
              <p>点击按钮更改图片颜色。</p>
              <img src="https://atts.w3cschool.cn/images%2Fw3c%2F20220506-154940.png" alt="示例图片"> <!-- 替换为编程狮的图片 -->
              <h3>背景颜色为:# <span id="colorCode">0f5257</span></h3>
              <button onclick="changeColor()" class="btn1">生成颜色</button>
            </div>
          </div>
          <script>
              function changeColor() {
                let hexNumbers = [ // 定义十六进制颜色字符数组
                    "0", "1", "2", "3", "4", "5", "6", "7", "8", "9",
                    "A", "B", "C", "D", "F"
                ];
                let hexColorCode = ""; // 初始化颜色代码字符串
                for (let i = 0; i < 6; i++) { // 循环生成 6 位颜色代码
                    let randomIndex = Math.floor(Math.random() * hexNumbers.length);
                    hexColorCode += hexNumbers[randomIndex];
                }
                document.getElementById("colorCode").innerHTML = hexColorCode; // 更新显示的颜色代码
                document.getElementsByTagName("img")[0].style.background = "#" + hexColorCode; // 应用新颜色
              }
          </script>
    </body>
</html>

将代码复制至 > HTML在线编译器查看效果

代码解析

  1. HTML 部分
    • 使用 <img> 标签引入图片,并设置相应的 src 属性。
    • 创建一个包含文本、图片和按钮的容器,用于展示和交互。

  1. CSS 部分
    • 为 body 设置背景颜色。
    • 使用 Flexbox 布局使容器居中。
    • 为文本添加动画效果,使用 @keyframes 定义颜色变化的关键帧。

  1. JavaScript 部分
    • 定义一个包含十六进制颜色字符的数组。
    • 通过循环生成 6 位随机颜色代码。
    • 更新页面上显示的颜色代码,并将新颜色应用到图片背景。

编程狮课程推荐

如果你想更深入地学习 HTML、CSS 和 JavaScript,欢迎访问 编程实战。我们提供以下相关课程:

  • HTML + CSS 基础实战
  • JavaScript 基础实战
  • Bootstrap 前端开发框架
  • jQuery 入门实战
  • 更多实战课程查看编程实战

在编程狮,我们致力于为每一位学习者提供高质量的编程教育资源,帮助你实现从入门到精通的飞跃!

通过今天的教程,你已经学会了如何使用 HTML、CSS 和 JavaScript 实现图片颜色的随机更改。希望你能继续探索并将其应用到你的项目中。

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

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

相关文章

CAN通信收发测试(USB2CAN模块测试实验)

1.搭建测试环境 电脑&#xff1a;安装 USB 驱动&#xff0c;安装原厂调试工具&#xff0c;安装cangaroo&#xff08;参考安装包的入门教程即可&#xff09; USB驱动路径&#xff1a;~\CAN分析仪资料20230701_Linux\硬件驱动程序 原厂调试工具路径&#xff1a;~\CAN分析仪资料2…

OSCP备战-BSides-Vancouver-2018-Workshop靶机详细步骤

一、靶机介绍 靶机地址&#xff1a;https://www.vulnhub.com/entry/bsides-vancouver-2018-workshop%2C231/ 靶机难度&#xff1a;中级&#xff08;CTF&#xff09; 靶机发布日期&#xff1a;2018年3月21日 靶机描述&#xff1a; Boot2root挑战旨在创建一个安全的环境&…

PDF转Markdown/JSON软件MinerU最新1.3.12版整合包下载

MinerU发布至今我已经更新多版整合包了&#xff0c;5天前MinerU发布了第一个正式版1.0.1&#xff0c;并且看到在18小时之前有更新模型文件&#xff0c;我就做了个最新版的一键启动整合包。 2025年02月21日更新v1.1.0版整合包 2025年02月27日更新v1.2.0版整合包 2025-06-05 更…

【深入学习Linux】System V共享内存

目录 前言 一、共享内存是什么&#xff1f; 共享内存实现原理 共享内存细节理解 二、接口认识 1.shmget函数——申请共享内存 2.ftok函数——生成key值 再次理解ftok和shmget 1&#xff09;key与shmid的区别与联系 2&#xff09;再理解key 3&#xff09;通过指令查看/释放系统中…

编程基础:执行流

能帮到你的话&#xff0c;就给个赞吧 &#x1f618; 文章目录 执行流同步&#xff1a;顺序执行&#xff0c;只有一个执行流异步&#xff1a;新开后台(次)执行流&#xff0c;后台执行流要确保不能影响主执行流。共有两个执行流。 阻塞&#xff1a;任务阻塞执行流&#xff0c;导致…

理解非结构化文档:将 Reducto 解析与 Elasticsearch 结合使用

作者&#xff1a;来自 Elastic Adel Wu 演示如何将 Reducto 的文档处理与 Elasticsearch 集成以实现语义搜索。 Elasticsearch 与业界领先的生成式 AI 工具和提供商有原生集成。欢迎观看我们的网络研讨会&#xff0c;了解如何超越 RAG 基础&#xff0c;或使用 Elastic 向量数据…

[面试精选] 0094. 二叉树的中序遍历

文章目录 1. 题目链接2. 题目描述3. 题目示例4. 解题思路5. 题解代码6. 复杂度分析 1. 题目链接 94. 二叉树的中序遍历 - 力扣&#xff08;LeetCode&#xff09; 2. 题目描述 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 3. 题目示例 示例 1 : 输入&…

学习笔记(23): 机器学习之数据预处理Pandas和转换成张量格式[1]

学习笔记(23): 机器学习之数据预处理Pandas和转换成张量格式[1] 学习机器学习&#xff0c;需要学习如何预处理原始数据&#xff0c;这里用到pandas&#xff0c;将原始数据转换为张量格式的数据。 1、安装pandas pip install pandas 2、写入和读取数据 >>创建一个人工…

2025年6月6日第一轮

2025年6月6日 The rapid in Chiese industdy is developnig e,and it is From be in a enjoy a deep is developing The drone industry in China is developing The drone industy in china develops rapidly and is in a leading position in in the world. The dro…

12-Oracle 23ai Vector 使用ONNX模型生成向量嵌入

一、Oracle 23ai Vector Embeddings 核心概念​ 向量嵌入&#xff08;Vector Embeddings&#xff09;​​ -- 将非结构化数据&#xff08;文本/图像&#xff09;转换为数值向量 - - 捕获数据的语义含义而非原始内容 - 示例&#xff1a;"数据库" → [0.24, -0.78, 0.5…

pytorch 与 张量的处理

系列文章目录 文章目录 系列文章目录一、Tensor 的裁剪二、Tensor 的索引与数据筛选torch.wheretorch.indicestorch.gathertorch.masked_selecttorch.taketorch.nonzero&#xff08;省略&#xff09; 三、Tensor 的组合与拼接torch.cattorch.stack 四、Tensor的切片chunksplit …

layer norm和 rms norm 对比

Layer norm # Layer Norm 公式 mean x.mean(dim-1, keepdimTrue) var x.var(dim-1, keepdimTrue) output (x - mean) / sqrt(var eps) * gamma beta特点&#xff1a; 减去均值&#xff08;去中心化&#xff09;除以标准差&#xff08;标准化&#xff09;包含可学习参数 …

Java高级 | 【实验六】Springboot文件上传和下载

隶属文章&#xff1a;Java高级 | &#xff08;二十二&#xff09;Java常用类库-CSDN博客 系列文章&#xff1a;Java高级 | 【实验一】Springboot安装及测试 |最新-CSDN博客 Java高级 | 【实验二】Springboot 控制器类相关注解知识-CSDN博客 Java高级 | 【实验三】Springboot 静…

VBA进度条ProgressForm1

上一章《VBA如何使用ProgressBar进度条控件》介绍了ProgressBar控件的使用方法&#xff0c;今天我给大家介绍ProgressForm1进度条的使用方法&#xff0c;ProgressForm1是集成ProgressBar控件和Label控件的窗体&#xff0c;可以同时显示进度条和百分比&#xff0c;如下图&#x…

行为型设计模式之Interpreter(解释器)

行为型设计模式之Interpreter&#xff08;解释器&#xff09; 前言&#xff1a; 自己的话理解&#xff1a;自定义一个解释器用来校验参数或数据是否合法。 1&#xff09;意图 给定一个语言&#xff0c;定义它的文法的一种表示&#xff0c;并定义一个解释器&#xff0c;这个解…

深入解析 CAS 操作

一、CAS 的本质&#xff1a;硬件级别的乐观锁 CAS&#xff08;Compare-And-Swap&#xff0c;比较并交换&#xff09; 是一种原子操作指令&#xff0c;用于实现对共享变量的无锁并发修改。它是现代多核处理器支持的底层硬件指令&#xff0c;也是构建高效并发数据结构&#xff0…

vue3+TS+eslint9配置

记录eslint升级到9.x的版本之后遇到的坑 在 ESLint 9 中&#xff0c;配置方式发生了变化。Flat Config 格式&#xff08;eslint.config.js 或 .ts&#xff09;不再支持 extensions 选项。所以vscode编辑器中的 extensions 需要注释掉&#xff0c;要不然保存的时候不会格式化。…

【bug】Error: /undefinedfilename in (/tmp/ocrmypdf.io.9xfn1e3b/origin.pdf)

在使用ocrmypdf的时候&#xff0c;需要Ghostscript9.55及以上的版本&#xff0c;但是ubuntu自带为9.50 然后使用ocrmypdf报错了 sudo apt update sudo apt install ghostscript gs --version 9.50 #版本不够安装的版本为9.50不够&#xff0c;因此去官网https://ghostscript.c…

Redis :String类型

String类型 String是Redis中的字符串&#xff0c;是Redis中最基本的数据类型&#xff0c;直接是按照二进制数据的进行存储 Redis中的所有key都是String类型&#xff0c;但是value是有差别的 常见的命令 set 将String类型的value存储到key中&#xff0c;如果之间有相同的ke…

第18节 Node.js Web 模块

什么是 Web 服务器&#xff1f; Web服务器一般指网站服务器&#xff0c;是指驻留于因特网上某种类型计算机的程序。 Web服务器的基本功能就是提供Web信息浏览服务。它只需支持HTTP协议、HTML文档格式及URL&#xff0c;与客户端的网络浏览器配合。 大多数web服务器都支持服务…