vue Pinia 全局主题切换

news2024/11/14 20:02:06

文章目录

      • vue Pinia 全局主题切换
          • 基本环境
          • 结果展示
          • 过程解析


vue Pinia 全局主题切换

目的 : 实现单页面上切换主题,例如 关灯或开灯;

环境: vue3.0 + vite + Pinia

基本环境
// tsconfig.json 文件中 新增路径配置 导入自定义文件时可以之间@导入
{
  "compilerOptions": {
	"baseUrl": "./",
    "paths": {
      "@/*":["src/*"]
    }
  },
}
// main.ts
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
import { createPinia } from 'pinia'
import router from '@/router/router'


// 创建app为vue实例根组件或全局组件;
const app = createApp(App)
// vue实例添加router组件
app.use(router)
// vue实例添加pinia组件
app.use(createPinia())
// vue实例挂载到index.html页面
app.mount('#app')

// app.vue
<script setup lang="ts">
// 导入引入的组件
import { NConfigProvider,NGlobalStyle, zhCN, dateZhCN,useOsTheme} from 'naive-ui'
import {useThemeStore} from '@/store/theme'
// themeStore 主题实例
const themeStore = useThemeStore()
</script>

<template>
  <!-- 全局处理 颜色组件 -->
  <n-config-provider 
    :theme="themeStore.theme"
    :locale="zhCN"
    :date-locale="dateZhCN">
    	<!-- 组件渲染出口 -->
    	<router-view></router-view>
    <n-global-style />
  </n-config-provider>
</template>

默认路由router加载 /路径,所以新建了一个index.vue用来组装页面;

// ViewHead.vue 页面 头部组件,导入到index.vue中
<script lang="ts" setup>
import { onMounted,ref,reactive,computed,onBeforeMount,onUpdated,onUnmounted,watch} from 'vue';
import {NButton,useOsTheme} from 'naive-ui'
import { update } from 'lodash';
import {useThemeStore} from '@/store/theme'
// 主题标记
const themeFlag=ref(true)
// themeStore
const theme = useThemeStore()
// 获取当前系统主题
const osTheme = useOsTheme();
// 监听当前操作系统主题
watch(osTheme,osTheme=>{
    if(osTheme){
        if(osTheme==="dark"){
          themeFlag.value=true
        }else{
          themeFlag.value=false
        }
        updateTheme()
    }
},{
    // 第一次绑定时会初始化立即执行一次
    immediate:true
})
// 变更主题
function updateTheme(){
        themeFlag.value=!themeFlag.value
        theme.setTheme(themeFlag.value);
}
</script>
<template>
    <h2>测试{{ "haha" }}</h2>
    <n-button  @click="updateTheme" strong secondary type="success">
      {{themeFlag?"光明":"黑暗"}}
    </n-button>
</template>
<style lang="less" scoped>

</style>

Pinia Store 组件的使用,用来缓存主题的全局状态

import {darkTheme,lightTheme} from 'naive-ui'
import { defineStore } from 'pinia'
import { ref, watch} from 'vue'
import type {GlobalTheme} from 'naive-ui'

// themeStore of pinia
export const useThemeStore = defineStore('themeStore',()=>{
    // theme ref var
    const theme = ref<GlobalTheme>(lightTheme)
    // actions: update Theme 
    function setTheme(themes:boolean){
        if(themes){
            // true lightTheme
            theme.value  = lightTheme
        }else{
            // false darkTheme
            theme.value  = darkTheme
        }
    }

    return {
        theme,
        setTheme
    }
})

目录结构

src
├─api
├─assets
├─components
├─router
├─store
	├─theme.ts
├─view
	├─fixedcomponent
		├─ViewHead.vue
	├─index.vue
App.vue
main.ts
结果展示

开灯效果
关灯效果

过程解析

因为使用了NaiveUI所以就使用了其支持的全局化配置Config Provider 即: App.vue 中的<n-config-provider>标签 ,包裹整个页面的渲染出口;

因为触发切换的组件在ViewHead.vue子组件内所以需要使用 Pinia store theme.ts来存储全局的主题状态变化和主题变更的触发;

ViewHead.vue中使用 n-button 按钮即可 通过 useThemeStore()中的setTheme()方法修改其theme的状态属性, 进而改变n-config-provider 标签的:theme属性

实现初次加载页面时根据系统的主题来修改页面的theme主题状态, 在ViewHead.vue中通过watch监听useOsTheme()即可实现;

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

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

相关文章

Java多态

Java多态\color{black}{\huge{Java多态}}Java多态 多态 1. 什么是多态&#xff1f; 多态&#xff1a;同种类型的对象&#xff0c;执行同一个任务&#xff0c;会表现出不同的行为特征&#xff0c;这就是多态(这种解释顶级抽象) 再细致一点说多态就是为不同的数据类型提供了同…

RK3399平台开发系列讲解(内存篇)ARM64虚拟地址空间布局

🚀返回专栏总目录 文章目录 一、虚拟地址空间划分二、用户虚拟地址空间布局三、内核地址空间布局沉淀、分享、成长,让自己和他人都能有所收获!😄 📢 本篇章让我们一起看一下ARM64虚拟地址空间的布局。 一、虚拟地址空间划分 因为目前应用程序没有那么大的内存需求,所…

知识点9--Docker容器的数据卷

我前面介绍容器命令的时候&#xff0c;最后说过一个cp命令&#xff0c;可以把容器和宿主机之间的文件互相拷贝&#xff0c;保证数据的持久化&#xff0c;但是这种持久化偏向于比较独立完整的文件&#xff0c;大家有没有想过如果遇到成体系的数据保存&#xff0c;比如我整个数据…

精彩数据:2021年我国民旅客周转量6530亿公里,审定受理飞机2803架

2021年是特殊的一年&#xff0c;全体民航成员在努力克服疫情防控、经营亏损、安全压力等困难交织叠加的影响下&#xff0c;切实的推动了民航的高质量发展&#xff0c;再各项工作上都取得了较好的成绩。下面是小编使用可视化互动平台对民航发展统计报告进行报表数据处理分析后得…

超市商城小程序开发,在线盈利途径

随着消费意识的提高和零售业的不断升级&#xff0c;小程序已经成为目前重要的线上发展形势之一且具有很强的发展活力&#xff0c;在此发展机遇下&#xff0c;很多企业开始布局线上渠道&#xff0c;进入电商行业。超市作为日常生活中最常见、数量最多的线下门店&#xff0c;当然…

[基因遗传算法]原理思想和python代码的结合理解之(一) :单变量

读《遗传算法的Python实现&#xff08;通俗易懂&#xff09;》佳文的思考与笔记整理. 我们拥有一个目标函数y10⋅sin(5x)7⋅cos(4x)y10 \cdot sin(5x)7\cdot cos(4x)y10⋅sin(5x)7⋅cos(4x) def aim(x):return 10*np.sin(5*x)7*np.cos(4*x)约束范围(这里是定义域):x∈[0,5]x \…

如何选择分度带(中央子午线)

如何选择分度带(中央子午线) 发布时间&#xff1a;2018-01-17 版权&#xff1a; 同步视频教程&#xff1a;如何选择中央子午线或者分度带 播放 什么是中央子午线&#xff1f; 什么是分度带? 【百度百科】 第一步&#xff1a;查看你所下载(或者要套合的范围)的图像的经纬…

盘点| 爆款小游戏的开发引擎

微信推出小游戏已有4年&#xff0c;期间不断涌现爆款。作为可以不用下载安装直接在线玩的小程序游戏&#xff0c;小游戏渐渐成为不少人的心头好。今天就来盘点一下那些爆款小游戏用到的游戏开发引擎&#xff1a; 一、Cocos 必须得把Cocos放在第一个讲&#xff0c;毕竟近期的羊了…

计量经济学

计量经济学 复习题 题型&#xff1a;选择2*10&#xff1b;填空2*10&#xff1b;名词解释4*5&#xff1b;综合题10*4 一 选择填空考点 1. 截面数据&#xff0c;时间序列&#xff0c;面板数据定义。P12/1.3.3 截面数据&#xff1a;同一时间&#xff08;时期或时点&#xff09;某个…

艾美捷胆固醇肉豆蔻酸酯说明书和相关研究

艾美捷胆固醇肉豆蔻酸酯以结晶固体形式提供。储备溶液可以通过将胆甾醇肉豆蔻酸酯溶解在所选溶剂中来制备。肉豆蔻酸胆甾醇可溶于有机溶剂氯丨仿&#xff0c;应使用惰性气体吹扫&#xff0c;浓度约为10mg/ml。 艾美捷胆固醇肉豆蔻酸酯基本参数&#xff1a; CAS#&#xff1a;19…

vue中使用图像编辑器tui-image-editor(一)

vue中使用图像编辑器tui-image-editor(一) 场景&#xff1a;需要对图片进行旋转、缩放、裁剪、涂鸦、标注、添加文本等。 效果-图1 1、基本介绍 官网&#xff1a;https://ui.toast.com/tui-image-editor 官方GitHub地址&#xff1a;https://github.com/nhn/tui.image-edito…

数据库设计

概述 数据库设计是一项十分复杂的操作&#xff0c;首先需要理清数据之间的关系&#xff0c;绘制ER图&#xff0c;接着根据ER图设计Relation Schema&#xff0c;最后添加字段属性和索引生成数据表。一个好的ER图是一个数据库的基础。 数据库设计的好坏中最重要的一项指标就是重…

完整版在xcode打测试专用ipa包流程​

前言&#xff1a;有时候&#xff0c;想要把自己的程序运行在别人的iphone手机上&#xff0c;但又不能通过本地真机调试的方法安装&#xff0c;这个时候我们就要打一个测试专用的ipa包给远方的测试小伙伴们测试。​ 步骤&#xff1a;​ 首先希望你的发布证书已经安装好了。​ 1.…

分布式文件存储系统FastDFS[2]-上传和下载文件工具类

一、文件上传流程 1 时序图 2 流程说明 客户端访问Tracker Tracker 返回Storage的ip和端口 客户端直接访问Storage&#xff0c;把文件内容和元数据发送过去。 Storage返回文件存储id。包含了组名和文件名 1 添加依赖 <dependencies><dependency><groupId&g…

基于jsp+mysql+ssm峰值预警停车场管理系统-计算机毕业设计

项目介绍 随着城市建设与经济的不断发展,城市车辆的数量也不断增涨,为解决停车问题修建停车场。基于经营、安全、管理等多角度的考虑&#xff0c;希望在目前传统的大型车库管理系统中有机地结合车牌识别技术&#xff0c;以求得日后在停车库运营时更安全、管理上更细致、经营中…

13个小众有趣的网站,只有程序员才看得懂

欢迎来到程序员的世界&#xff0c;分享一些关于程序员的小众网站&#xff0c;不仅干货满满的实用类网站&#xff0c;也有一些有趣的娱乐网站&#xff0c;有些网站只有程序员才看得懂。1、程序员音乐 地址&#xff1a;https://musicforprogramming.net/ 一个仿代码样式的背景音乐…

使用JAR签名进行代码签名

JavaArchive(JAR)包格式可用于打包Java应用程序和库。 签名的JAR文件可以选择包含来自TSA时间戳响应&#xff0c;使用RFC#3161格式。 添加JAR签名者添加JAR签名者的链接&#xff0c;SignServer中的JAR签名器称为JArchiveSigner。 要配置JArchiveSigner&#xff0c;请按照以下…

[附源码]计算机毕业设计农产品销售网站Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

用R语言模拟M / M / 1随机服务排队系统

本文中我在R中构造一个简单的M / M / 1队列的离散事件模拟 。最近我们被客户要求撰写关于随机服务的研究报告&#xff0c;包括一些图形和统计输出。 模拟变量 像往常一样&#xff0c;我们从模拟及其检测所需的变量 开始。 t.end <- 10^5 # 模拟的持续时间 t.clock <- 0…

【OpenCV-Python】教程:4-3 Shi-Tomasi 角点检测

OpenCV Python Shi-Tomasi 角点检测器 【目标】 Shi-Tomasi 角点检测器cv2.goodFeaturesToTrack 【理论】 上一个章节中学习了Harris角点&#xff0c;J. Shi and C. Tomasi 做了一些修改&#xff0c;Good Features to Track显示了比Harris角点更好的效果。 Harris 角点检测…