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

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

效果图:

源码:

html 复制代码
<!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) {
            // 隐藏所有主题的box
            var themes = document.querySelectorAll('[id^="item"]');
            themes.forEach(function(theme) {
                theme.style.display = 'none';
            });

            // 显示选中的主题的box
            var selectedTheme = document.getElementById(themeId);
            selectedTheme.style.display = 'block';
        }
    </script>

</body>
</html>

源码解析:

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

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

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

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

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

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

相关推荐
迦南giser几秒前
前端性能——传输优化
前端
小白_ysf5 分钟前
Vue 中常见的加密方法(对称、非对称、杂凑算法)
前端·vue.js·算法
2501_944448001 小时前
Flutter for OpenHarmony衣橱管家App实战:支持我们功能实现
android·javascript·flutter
人工智能训练6 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
会跑的葫芦怪7 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
xiaoqi9228 小时前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233228 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头882110 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas13610 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠10 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6