UniApp Vue2 动态修改 SCSS 伪类颜色

一、需求说明

在 UniApp Vue2 项目中,导航栏文字、底部下划线为静态白色,现需要从本地缓存读取自定义颜色值 ,动态控制文字颜色与 :after 伪类下划线颜色。

二、技术难点

  1. 普通 DOM 元素可通过行内 :style 动态改色;

  2. CSS 伪类(:after / :before)不属于 DOM 节点 ,无法直接绑定行内样式,需借助 CSS 变量实现动态赋值。

三、完整实现步骤

1. JS 逻辑:读取本地缓存色值

在页面 data 中定义变量,从缓存读取配色,并设置默认值防止空值失效。

复制代码

export default { data() { return { // 读取缓存中的导航栏颜色,无数据则默认白色 userHeaderBackground: uni.getStorageSync('navigationBarColor') || '#FFFFFF' } } }

2. 模板改造:绑定行内样式 + 注入 CSS 变量

  1. 外层容器挂载自定义 CSS 变量,供伪类使用;

  2. 导航子项通过 :style 动态绑定文字颜色。

复制代码

<template> <view class="ss-scroll-navbar" :style="{'--nav-active-color': userHeaderBackground}" > <view class="nav-item" :style="{color: userHeaderBackground}"> <view class="title">导航选项</view> </view> </view> </template>

3. SCSS 样式:通过 CSS 变量替换静态色值

删除样式内静态颜色,伪类使用 var(变量名) 读取动态颜色,同时修正代码中 upx 拼写错误(UniApp 标准单位为 rpx)。

复制代码

.ss-scroll-navbar { width: 100%; height: 80rpx; box-shadow: 0 2rpx 8rpx rgba(0, 0, 0, .06); white-space: nowrap; text-align: start; .nav-item { height: 80rpx; text-align: center; padding: 0rpx 20rpx; display: inline-block; position: relative; font-size: 32rpx; .title { line-height: 80rpx; } &:after { content: ''; width: 0; height: 0; /* 使用动态CSS变量 */ border-bottom: 4rpx solid var(--nav-active-color); position: absolute; left: 50%; bottom: 0; transform: translateX(-50%); transition: .3s; } } }

四、颜色实时更新(拓展)

若项目支持手动切换颜色并持久化到本地缓存,修改变量后视图会自动刷新:

复制代码

methods: { // 切换自定义颜色 changeNavColor(color) { uni.setStorageSync('navigationBarColor', color) this.userHeaderBackground = color } }

相关推荐
这是个栗子4 小时前
微信小程序开发(九)- uni-app微信小程序商城
微信小程序·小程序·uni-app·vue·vuex
鹤鸣的日常1 天前
前端运行时动态环境变量方案
前端·react.js·docker·前端框架·vue·gitlab
来杯@Java2 天前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
医疗信息化王工2 天前
医院自律端系统——预警处置模块全栈实战(ASP.NET Core + Vue3 + Quartz 定时调度)
mysql·postgresql·vue·asp.net core·quartz
大大杰哥2 天前
Vue2学习(1)--了解基本方法与概念
javascript·学习·vue
Agatha方艺璇3 天前
前端开发技术复习笔记
vue·bootstrap·css3·html5·web
小葛要努力3 天前
创建vue2项目
程序人生·vue
七仔啊3 天前
基于海康门禁的人员计数系统
vue
步十人4 天前
【Vue3】前置知识简单概述(包括ES6核心语法,模块化ESM以及npm基础)
arcgis·npm·vue·es6