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 } }

相关推荐
小葛要努力16 天前
安装nvm 管理node.js版本实现vue2和vue3项目共存
node.js·vue·nvm
这里是杨杨吖17 天前
SpringBoot+Vue高校在线考试系统 附带详细运行指导视频
vue·在线考试·springboot
wuxia211817 天前
在5种环境中编写点击元素改变内容和颜色的JavaScript程序
javascript·微信小程序·vue·jquery·react
Sweet锦17 天前
Vue3 集成 ApexCharts 避坑指南:从动画失效到自定义指令的完美解决方案
vue·echarts
王小王-12318 天前
基于深度学习的个性化音乐推荐系统的设计与开发
人工智能·深度学习·mysql·vue·推荐算法·个性化音乐推荐系统·音乐预测
alexander06818 天前
使用vite脚手架,快速创建一个vue3的项目
vue
这是个栗子20 天前
微信小程序开发(九)- uni-app微信小程序商城
微信小程序·小程序·uni-app·vue·vuex
鹤鸣的日常21 天前
前端运行时动态环境变量方案
前端·react.js·docker·前端框架·vue·gitlab
来杯@Java22 天前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis