首页 > 其他分享 >在Vue3中创建动态主题切换功能

在Vue3中创建动态主题切换功能

时间:2024-07-31 15:57:16浏览次数:17  
标签:Vue3 color 创建 主题 link 切换 light currentTheme

随着现代Web开发的进步,用户体验变得愈发重要。在这方面,实现动态主题切换功能无疑是提高用户体验的有效方式。通过动态主题切换,用户可以根据自己的喜好选择明亮的主题或暗色主题,提供了更个性化、更舒适的使用体验。今天,我们将通过一个简洁的示例来展示,如何在Vue 3中实现动态主题切换功能,使用setup语法糖来优化我们的代码。

项目准备

首先,确保你的开发环境中已经安装了Vue 3。你可以使用Vue CLI或Vite来创建一个新的项目。这里我们使用Vite来启动一个新项目。

npm init vite@latest my-vue3-app --template vue
cd my-vue3-app
npm install

安装完成之后,打开项目,使用你的代码编辑器准备进行接下来的步骤。

主题样式

我们将在src/assets下创建两个基本的主题样式文件:light.cssdark.css

light.css

body {
    background-color: #ffffff;
    color: #333333;
}

header {
    background-color: #f0f0f0;
    padding: 10px;
    border-bottom: 1px solid #ddd;
}

dark.css

body {
    background-color: #1e1e1e;
    color: #f0f0f0;
}

header {
    background-color: #444444;
    padding: 10px;
    border-bottom: 1px solid #666;
}

创建动态主题切换功能

现在我们已经定义了基本的样式,接下来在src/components目录下创建一个新的组件ThemeToggle.vue,用于实现主题切换功能。

<template>
  <div>
    <header>
      <h1>动态主题切换示例</h1>
      <button @click="toggleTheme">{{ currentTheme === 'light' ? '切换到暗色主题' : '切换到亮色主题' }}</button>
    </header>
    <main>
      <p>欢迎使用我们的网站!您可以选择您喜欢的主题模式。</p>
    </main>
  </div>
</template>

<script setup>
import { ref, watch } from 'vue';

// 主题状态
const currentTheme = ref('light');

// 切换主题功能
const toggleTheme = () => {
  currentTheme.value = currentTheme.value === 'light' ? 'dark' : 'light';
};

// 监听主题变化,添加相应的CSS类
watch(currentTheme, (newTheme) => {
  document.body.className = newTheme; // 更换body的class
  // 动态引入CSS文件
  const linkElement = document.getElementById('theme-style') || createLinkElement();
  linkElement.href = newTheme === 'light' ? '/src/assets/light.css' : '/src/assets/dark.css';
});

// 创建链接元素
const createLinkElement = () => {
  const link = document.createElement('link');
  link.rel = 'stylesheet';
  link.id = 'theme-style';
  link.href = '/src/assets/light.css'; // 默认主题
  document.head.appendChild(link);
  return link;
};

// 在组件挂载时执行
document.body.className = currentTheme.value; // 默认使用亮色主题
</script>

<style scoped>
main {
    padding: 20px;
}
button {
    padding: 10px 20px;
    border: none;
    border-radius: 5px;
    cursor: pointer;
}
</style>

代码详解

在上述代码中,我们首先定义了一个响应式变量currentTheme,用于保存当前的主题状态。toggleTheme函数会在每次用户点击按钮时被调用,以切换主题。

我们还监控currentTheme的变化,当主题发生变化时,我们会更新bodyclassName以便应用不同的样式。同时,我们通过动态创建一个<link>标签来加载相应的CSS文件,这样无论是主题切换还是初次加载,都会获取到正确的样式。

在应用中使用ThemeToggle

现在我们可以在src/App.vue文件中使用ThemeToggle组件:

<template>
  <div id="app">
    <ThemeToggle />
  </div>
</template>

<script setup>
import ThemeToggle from './components/ThemeToggle.vue';
</script>

<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

运行与测试

在命令行中运行项目:

npm run dev

打开浏览器,访问http://localhost:3000,你将看到一个包含主题切换按钮的界面。尝试点击按钮,观察主题的变化效果。

结语

通过以上步骤,我们在Vue 3中成功实现了一个动态主题切换功能。这个功能不仅提升了用户体验,也为后续功能的扩展奠定了基础。你可以根据自己的需求,进一步优化和扩展这一功能,比如使用本地存储保存用户选择的主题,或者为不同的页面提供不同的主题配置等。


最后问候亲爱的朋友们,并邀请你们阅读我的全新著作

在这里插入图片描述

标签:Vue3,color,创建,主题,link,切换,light,currentTheme
From: https://blog.csdn.net/yuanlong12178/article/details/140792224

相关文章

  • 如何在 python 中使用矩阵分解从 3 个不同的矩阵(2 个交互矩阵和 1 个相似矩阵)创建一个
    我有3个不同大小的矩阵A、B、C,它们有一些共同的元素。A(相似性)与B(交互)有一些共同元素,但与C(第二交互矩阵)没有共同元素。B有一些与C相同的元素。我想创建一个基于B和C的矩阵M,但提供基于A、B、C的输出,就像推荐系统类型一样,其中根据评分、观看次数和偏好推荐电影。例......
  • Go--创建以当前时间命名的excel文件
    下载依赖包goget-ugithub.com/xuri/excelize/v2 代码packagemainimport("fmt""github.com/xuri/excelize/v2""time")funcmain(){//获取当前时间now:=time.Now()filename:=fmt.Sprintf("%s.xlsx&......
  • 在 Python 中创建和/或检查编号变量的优雅方法
    我是一个试图学习Python的老家伙,所以我最后的编码经验是使用BASIC-不,不是VisualBasic。我理解一些与Python相关的概念,但我处于初级编码阶段,所以我使用“强力”逻辑编写了这个项目-基本上,将字符串分解为单个字母,然后用经典的“”测试每个字母猜单词类型的游戏。......
  • 在绘图破折号地图框中切换几何图层
    我使用下面的帖子在plotlymapbox上绘制maki符号。PlotlyMapbox标记未渲染(圆圈除外)importdashfromdashimportDash,dcc,html,Input,Outputimportdash_bootstrap_componentsasdbcimportplotly.expressaspximportplotly.graph_objsasgoimportnum......
  • Vue3 - 最新详细实现网站内部打开预览 office 全套附件,在页面弹窗内解析预览 word文档
    前言如果您需要Vue2版本,请访问这篇文章。在vue3|nuxt3项目开发中,详解实现项目内部“打开解析预览各种office文档”通用预览插件,支持弹出一个窗口在弹框内预览或者直接显示在页面某个div容器里面,解析预览word文档、excel电子表格、ppt演示文稿、pdf文档、txt文......
  • 手把手带你创建HAL版本MDK工程模板
    如何快速开发STM32项目?我们总不能每次开发一个项目就搭建一次工程,这样效率太低了。通常我们会使用一个模板工程,需要开发新项目的时候拿出来添加一些对应的模块及业务代码,一个项目就开发完成了。但对于新手朋友来讲,如何创建一个工程模板对他们来讲是个非常大的挑战。因为这个过......
  • 这本vue3编译原理开源电子书,初中级前端竟然都能看懂
    前言众所周知vue提供了很多黑魔法,比如单文件组件(SFC)、指令、宏函数、cssscoped等。这些都是vue提供的开箱即用的功能,大家平时用这些黑魔法的时候有没有疑惑过一些疑问呢。我们每天写的vue代码一般都是写在*.vue文件中,但是浏览器却只认识html、css、js等文件类型,明显是不认......
  • 如何在for循环中使用curve_fit函数在python中一次性创建多个回归?
    简而言之,我有两个矩阵,一个称为t,另一个称为y。每个都有7列。假设它们被称为a、b、c、d、e、f和g。我想要的是从a对a、b对b、...、g对g这两个矩阵进行回归。我已经设法使我的算法使用curve_fit对一列进行回归一次。但我真正希望的是它能够一次性完成7个回归......
  • 如何根据数组中的数据在 matplotlib 中创建 3D 线图?
    我已经使用SciPy和脚本对洛伦兹方程进行了数值求解:#LorenzEquationsSciPysolverimportnumpyasnpfromscipyimportintegratefrommathimportcosfrommatplotlibimportpyplotasplta,b=0,100sigma,rho,beta=10,28,8/3N=1000000h=(b-a)/f......
  • 尝试创建一个条形图,显示按性别和日期分组的每次购买所花费的总金额
    我正在尝试创建一个条形图来回答以下问题:哪种性别每年花的钱最多?我有一个数据集,其中列出了每笔交易,并附有每个条目所花费的金额、性别(男性、女性、其他)和日期(2014年10月16日、2015年9月8日、2016年7月29日等)。我想创建一个条形堆叠条形图,显示每年(仅当年)每个性别......