当前位置: 首页 > news >正文

【html】如何利用id选择器实现主题切换

今天给大家介绍一种方法来实现主题切换的效果 

效果图:

源码:

<!DOCTYPE html>
<html lang="zh">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.box{width: 200px;height: 200px;font-size: 25px;border: 2px solid #000;line-height: 200px;text-align: center;}#item1 .box {color: red;border-color: blue;}#item2 .box {color: orangered;background-color: aquamarine;border-color: green;border-radius: 30px;}#item3 .box {color: purple;background-color: yellow;border-color: pink;border-radius: 50%;}</style>
</head>
<body><!-- 当前显示的box --><div id="item2"><div class="box">内容</div></div><!-- 其他主题的box,隐藏起来 --><div id="item1" style="display: none;"><div class="box">内容</div></div><div id="item3" style="display: none;"><div class="box">内容</div></div><!-- 切换主题的按钮(示例) --><button onclick="switchTheme('item1')">主题1</button><button onclick="switchTheme('item2')">主题2</button><button onclick="switchTheme('item3')">主题3</button><script>function switchTheme(themeId) {// 隐藏所有主题的boxvar themes = document.querySelectorAll('[id^="item"]');themes.forEach(function(theme) {theme.style.display = 'none';});// 显示选中的主题的boxvar selectedTheme = document.getElementById(themeId);selectedTheme.style.display = 'block';}</script></body>
</html>

源码解析:

可以通过修改最外层的ID选择器来模拟修改主题。在你的例子中,.box 类有两个不同的样式定义,一个应用于 #item1 .box,另一个应用于 #item2 .box。这些样式根据它们所在的父元素的ID(item1 或 item2)来应用。

要模拟修改主题,你可以创建多个具有不同ID的父元素,并为每个父元素定义不同的.box样式。然后,你可以通过切换不同ID的父元素来模拟主题更改。

例如,你可以添加一个新的父元素,如 #item3,并为其.box类定义不同的样式:

在这个例子中,我添加了另外两个带有ID item1 和 item3 的父元素,并为它们各自的.box类定义了不同的样式。初始时,只有item2是可见的,其他两个是隐藏的。

我还添加了三个按钮,用于切换主题。当点击按钮时,switchTheme 函数会被调用,它隐藏所有主题的.box,并只显示所选主题的.box

这样,你就可以通过点击按钮来模拟修改主题了。当然,在实际应用中,你可能会有更复杂的主题和样式,以及更优雅的方式来管理这些主题的切换,比如使用JavaScript类、CSS变量或者CSS预处理器。

http://www.lryc.cn/news/374863.html

相关文章:

  • 服务器添加TLS域名证书核子之PKCS编解码
  • 使用 Selenium 自动化获取 CSDN 博客资源列表
  • 智能制造全闪解决方案,八大痛点,一网打尽
  • Python学习从0开始——Kaggle深度学习002
  • 比利时海外媒体宣发,发稿促进媒体通稿发布新形势-大舍传媒
  • 摄影构图:人像摄影和风景摄影的一些建议
  • 安卓实现输入快递单号生成二维码,摄像头扫描快递单号生成的二维码,可以得到快递信息
  • Mysql特殊用法分享
  • 一个开源的快速准确地将 PDF 转换为 markdown工具
  • 可通过小球进行旋转的十字光标(vtkResliceCursor)
  • python遍历文件夹并计算某类文件的数量,制图像文件到目标文件夹
  • 网络层只懂路由?这9个知识点被严重低估了
  • 最新的kali Linux源,解决apt update报错说没有数字签名
  • RAG与Langchain简介
  • 绕过网页的阻止复制
  • Jackson指定json的key
  • 谷歌发布Infini-Transformer模型—无限注意力机制长度,超越极限
  • 激光点云配准算法——Cofinet / GeoTransforme / MAC
  • socket--cs--nc简单实现反弹shell
  • CSS入门基础2
  • Mac vscode could not import github.com/gin-gonic/gin
  • MySQL修改用户权限(宝塔)
  • 论文阅读(一种新的稀疏PCA求解方式)Sparse PCA: A Geometric Approach
  • Chrome/Edge浏览器视频画中画可拉动进度条插件
  • pg修炼之道学习笔记
  • 使用宝塔面板部署Django应用(不成功Kill Me!)
  • c++深拷贝、浅拷贝
  • k8s核心组件
  • 反编译腾讯vmp
  • Ollama:本地部署大模型 + LobeChat:聊天界面 = 自己的ChatGPT