Vue 动态改变css文件

news2025/1/16 19:51:47

theme: smartblue

一、背景需求

现有 Vue3 项目,要求点击按钮后,会动态加载css文件内容

二、实现过程

2.1 相关代码

假设有 blue.css 和 red.css,要求点击加载对应文件

若想切换为原版样式,点击 back 回退到初始样式

```

this is a simple text

```

三、重点强调

3.1 资源名称变化

vue 项目打包后 (控制台输入 npm run build),项目中的 图片,js,css 文件地址都会改变,如:

index.js 会重命名为 index-e7c5d476.js

只有当他们放置在 public 目录下(允许设置多级子目录),文件的名称才会不变.

所以 blue.css 和 red.css 是放置在 /publc/css/xxx.css 中

3.2 资源地址变化

类似于上一个问题,打包后的资源地址也会对应改变,如:

/public/css/red.css 会变化为 css/red.css

需要我们根据当前项目环境动态加载地址变量。

设置过程如下:

在 src 同级目录创建 .env 和 .env.prd 文件,内容为(以 .env 文件为例):

VITE_APP_ENV = 'dev'

在 src 目录下创建 envConfig.js 文件,内容如下:

``` export const envConfig = { ENVTAG: import.meta.env.VITEAPP_ENV, };

```

对应的文件地址结构为:

2024-07-29_22-07-32.png

此时在代码中可以根据如下逻辑获取环境变量:

```

```

并且在 package.json 中,为 scripts -> build 追加 --mode prd 参数,指定读取哪一个配置文件

2024-07-29_22-12-16.png

若在控制台输入 npm run build 后,log 中看到 --mode prd 字样,则表明设置成功。

2024-07-29_22-12-44.png

3.3 修改资源前缀

在上述文件配置完毕后,即使我们打包了项目文件,也会看到 404 找不到资源的错误提示

2024-07-29_22-14-55.png

页面代码如下:

```

rel="icon" type="image/svg+xml" href="/vite.svg"> Vite + Vue rel="stylesheet" href="/assets/index-78058d01.css">

```

只有当 src 和 href 中的路径前缀为 ./ 时才能获取到对应资源,也就是说,

要将src="/assets/index-e7c5d476.js" 修改为 src="./assets/index-e7c5d476.js",

href="/assets/index-78058d01.css" 修改为 "href="./assets/index-78058d01.css"

我们可在 vite.conifg.js 中添加参数 base: './' 以去解决问题

2024-07-29_22-20-49.png

四、 优化 - 选项持久化

4.1 需求说明

现有优化需求,当用户选择样式后,下一次进入页面会自动加载点击的样式

4.2 依赖下载

控制台输入 npm i pinia-plugin-persistedstate pinia

下载 pinia 以及 持久化插件

4.3 环境配置

main.js 内容如下

``` import { createApp } from 'vue' import './style.css' import App from './App.vue'

import { createPinia } from 'pinia' import piniaPluginPersistedstate from 'pinia-plugin-persistedstate'

const pinia = createPinia() pinia.use(piniaPluginPersistedstate)

createApp(App) .use(pinia) .mount('#app')

```

4.4 创建全局变量

定义 currCss 全局变量,记录上一次点击的结果 ``` import { defineStore } from "pinia"; import {ref} from 'vue'

export const useStore = defineStore("store",() => { const currCss = ref()

return {
        currCss
    };
},
{
    persist: true,
}

);

```

4.5 调用全局变量

```

this is a simple text

``` 此时每次刷新页面后,都会保留上一次设置的样式,

根据如下浏览器显示结果,每次设置的对象都是保存在 localstorage

2024-07-29_23-00-12.png

4.6 参考文档

快速开始 | pinia-plugin-persistedstate (prazdevs.github.io)

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

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

相关文章

76.SAP ME - 归档

目录 1.归档 2.系统设置维护 3.后台处理执行 1.归档 可使用此功能将某一特定已完成产品的相关记录从活动的“在制品”(WIP) 数据库移动到归档数据库,这样可改进生产记录的检索。在一段时间内,WIP 数据库中的记录数量将增加。当系统在大量记录中进行搜…

c++ 内存管理(newdeletedelete[])

因为在c里面新增了类,所以我们在有时候会用malloc来创建类,但是这种创建只是单纯的开辟空间,没有什么默认构造的。同时free也是free的表面,如果类里面带有指针指向堆区的成员变量就会free不干净。 所以我们c增加了new delete和de…

pdf太大怎么压缩大小?这几种压缩方法操作起来很简单!

pdf太大怎么压缩大小?在数字化洪流席卷的当下,PDF文件的“臃肿”难题如同巨石般横亘于高效办公之路,它们不仅贪婪地吞噬着宝贵的存储空间,更如沉重的枷锁,拖曳着我们的工作进度,步入迟缓之境,试…

06 内置的整数、实数与复数

在 Python 中,内置的数字类型有整数、实数和复数,借助于标准库 fractions 中的 Fraction 对象可以实现分数及其运算,而 fractions 中的 Decimal 类则实现了更高精度的运算。 Python 支持任意大的数字,具体可以大到什么程度仅受内…

电阻液冷 可提升 3.3kV 中压负载-EAK水冷电阻器

电阻液冷 可提升 3.3kV 中压负载-EAK水冷电阻器 在工业和海洋应用中,水冷在削减电阻器封装方面至关重要的地方 在起重机、升降机、升降机和输送机等电机驱动应用中,风冷电阻器很常见,但在中压、高功率应用中,液体冷却胜出。 使…

IDEA项目的依赖(pom.xml文件)导入问题及解决

前言:该文章为转载,没有仔细的看 IDEA新建项目和pom.xml文件被修改时,右下角都会出现 Maven projects need to be imported(项目需要导入依赖) 如下,点击 Import Changes导入后,有时会一直处于…

【基础篇】Docker 概览 ONE

嗨,大家好!我是小竹笋,一名热爱创作的工程师。今天我将带领大家一起踏上探索 Docker 的奇妙之旅。我们先从 Docker 的历史和发展说起,然后再看看 Docker 和虚拟机之间的区别,最后了解一下 Docker 在各行各业的应用情况…

数据结构算法经典题目刨析(c语言)返回单链表的倒数第 k 个节点

💓 博客主页:C-SDN花园GGbond ⏩ 文章专栏:数据结构经典题目刨析(c语言) 一.题目描述 二.解题思路 方法一:计数器方式 先遍历链表,求出链表长度count倒数第k个节点,就是正数第count-k1个节点(下标为count…

《系统架构设计师教程(第2版)》第13章-层次式架构设计理论与实践-02-表现层框架设计

文章目录 1. 表现层设计模式1.1 MVC模式1.1.1 三个核心模块1)控制器 (Controller)2)模型 (Model)3)视图 (View): 1.1.2 过程1.1.3 优点1.1.4 应用 1.2 MVP模式1.3 MVVM模式 2. 使用XML设计表现层统一Web Form与 Windows Form的外观3. 表现层中…

⚠️ Buffer Overflow: 安全编码必备知识 ️

⚠️ Buffer Overflow: 安全编码必备知识 🛡️ ⚠️ Buffer Overflow: 安全编码必备知识 🛡️摘要引言正文内容一、缓冲区溢出基本概念 🧩二、常见场景及实际案例 🛠️2.1 利用不安全的函数2.2 堆溢出攻击 三、调试技巧 &#x1f…

算法入门:Java实现排序、查找算法

链接:算法入门:Java实现排序、查找算法 (qq.com) 冒泡/选择/插入/希尔排序代码 (qq.com) 快排/归并/堆排/基数排序代码 (qq.com)

Python酷库之旅-第三方库Pandas(053)

目录 一、用法精讲 196、pandas.Series.first方法 196-1、语法 196-2、参数 196-3、功能 196-4、返回值 196-5、说明 196-6、用法 196-6-1、数据准备 196-6-2、代码示例 196-6-3、结果输出 197、pandas.Series.head方法 197-1、语法 197-2、参数 197-3、功能 1…

【C++题解】1069. 字符图形5-星号梯形

问题&#xff1a;1069. 字符图形5-星号梯形 类型&#xff1a;嵌套循环、图形输出 题目描述&#xff1a; 打印字符图形。 输入&#xff1a; 一个整数&#xff08; 0<n<10 &#xff09;。 输出&#xff1a; 一个字符图形。 样例&#xff1a; 输入&#xff1a; 3输…

卷积神经网络(三)---案例分析

上面部分介绍了 PyTorch 中的卷积模块&#xff0c;接下来将会介绍几个卷积神经网络的案例&#xff0c;通过案例入手来介绍卷积神经网络的结构设计。 1. LeNet LeNet 是整个卷积神经网络的开山之作&#xff0c;1998年由 LeCun 提出&#xff0c;它的结构特别简单&#xff0c;我们…

看懂循环队列

循环队列的设计过程 1.循环队列2.设计循环队列的逻辑过程2.1 定义循环队列的数据结构2.2 初始化队列2.3 入队操作2.4. 出队操作2.5 判断队列状态2.5 获取队头和队尾的元素力扣相关题目完整代码 1.循环队列 循环队列是使用有限数组来模拟队列&#xff0c;与普通的队列不同的是&…

文献综述在确定先前研究中使用的方法学方法方面发挥什么作用

VersaBot一键生成文献综述 文献综述在确定先前研究中使用的方法学方法方面发挥着至关重要的作用&#xff0c;可以作为设计自己的方法论并证明其重要性的基础。就是这样; 1. 揭示现有方法&#xff1a; 通过探索与您的主题相关的研究&#xff0c;您将发现其他研究人员采用的不同…

普通人有必要学Python吗?学了之后能做什么?

目录 首先来说一下极其推荐的方向&#xff1a; 1、数据分析 2、科学计算 3、大数据框架 4、脚本开发 5、爬虫 6、Web框架 总结&#xff1a; 如果你还没有开始使用Python&#xff0c;答应我&#xff0c;把这个回答看完&#xff0c;如果你真的学习并深入使用过Python&…

锅总浅析虚拟化技术

常见的虚拟化技术有哪些&#xff1f;KVM集群解决方案有哪些&#xff1f;如何用Libvirt操作KVM组成集群&#xff1f;PVE构建虚拟化的特性和其架构又是怎样的&#xff1f;希望完本文&#xff0c;能帮您解答这些疑惑&#xff01; 一、常见虚拟化技术概述 虚拟化技术是一种通过软…

Qt 实现抽屉效果

1、实现效果和UI设计界面 2、工程目录 3、mainwindow.h #ifndef MAINWINDOW_H #define MAINWINDOW_H#include <QMainWindow> #include <QToolButton> #include <QPushButton> #include <vector> using namespace std;QT_BEGIN_NAMESPACE namespace…