当前位置: 首页 > news >正文

Vue:通过js控制css变量 - 一键修改全局样式

背景

最近接到一个需求:在Vue(版本是2.x)页面有个控制字体大小的选项,修改后全局表格内的字体会变化,且要新打开的页面也会变化。

需求整理

  1. 在页面上方设置一个修改布局大小的选项
  2. 点击后会出现滚动条,字体范围为923px,默认值为14px
  3. 拖动字体滚动条时,页面表格字体会随着滚动条值的变化而变化
  4. 用户每次打开页面时会读取上次设置的字体大小

本文章会记录完成这个需求的思考过程,如果需要直接看代码请拉至"代码实现"章节。

系统现状

技术框架:vue2+ElementUI,基于若依管理系统的二次开发系统

实现思路

  1. ElementUI有个控制全局大小的size变量,只要使用的控件不添加size属性,就会读取全局的size变量进行相应大小的展示。
    • 但该设置只能设置为预设的4种大小(defaultmeduimsmallmini)无法满足需求中的设置字体大小为指定像素(px)。
  2. 通过修改全局样式scss样式文件,需要在每个class声明fontSize样式

由上述思考后,决定采用方法2,但如果我用js每次都更新一大堆class中的fontSize,那太痛苦了,如果使用到的classfontSize属性能动态读取同一个变量,用户修改该变量的值后引用该变量的class值都能改变,那我只用js修改一个变量即可,那有没有这种方法呢?

css如何读取某个变量

CSS变量(也称为 CSS 自定义属性)允许你在 CSS 中定义可重用的值。具体特点如下:

定义:通过 -- 前缀命名,在 :root 或其他选择器(如其他的class)中定义。
使用:通过 var() 函数在 CSS 属性值中引用。
作用:提高样式的可维护性和一致性,便于全局修改样式。

/* 可由js控制的css传参*/
:root {--table-font-size: 14px;--ux-grid-height: 31px;
}
/* 使用var引用--table-font-size和--ux-grid-height变量,后文的ux-grid使用了.elx-table样式类*/
.elx-table.size--default {font-size: var(--table-font-size);height: var(--ux-grid-height);padding-top: 2px;/* 使用var引用--table-font-size变量*/.el-button {font-size: var(--table-font-size);/* 结合calc和min函数一起使用*/padding-top: min(calc(var(--ux-grid-height) - var(--table-font-size) - 13px), 20px);}
}

既然css已经提供了这种方法,那么最后一个小需求实现起来就更容易了:每次修改字体大小时触发值改变事件,修改字体大小后将值保存在cookievuex中,用户每次登陆时获取cookie中的值,如果没有值则默认取:root的大小。

代码实现

<template><el-tooltip content="调整字体" effect="dark" placement="bottom"><el-popover class="right-menu-item hover-effect"placement="bottom"width="200"trigger="click"><el-slider :min="9" :max="23" v-model="fontSize" :format-tooltip="(value)=>value + '像素'" @change="changeFontSize"></el-slider><i slot="reference" class="el-icon-s-operation"></i></el-popover></el-tooltip>
</template>
created() {this.fontSize = parseFloat(this.$store.state.app.tableFontSize)this.updateCssSize(CSS_FONT_SIZE_NAME, this.fontSize)
},
data() {return {fontSize: 0}
},
/*** 值变化事件*/
methods: {/** 修改字体大小事件*/changeFontSize(amount) {this.updateCssSize(CSS_FONT_SIZE_NAME, amount)// 保存到vuex中this.$store.dispatch('app/setTableFontSize', amount)// 表格的行高为fontSize+17,让行高随着字体的变化而变化let uxGridHeight = '--ux-grid-height'this.updateCssSize(uxGridHeight, amount + 17)this.refreshView()},/** 修改样式属性值 */updateCssSize(prop, value) {const newVal = parseFloat(value)document.documentElement.style.setProperty(prop, newVal  + 'px');},/** 重新加载已打开的其他标签页*/refreshView() {this.$store.dispatch('tagsView/delAllCachedViews', this.$route)const { fullPath } = this.$routethis.$nextTick(() => {this.$router.replace({path: '/redirect' + fullPath})})}
}// 在vuex中的代码
const mutations = {TOGGLE_SIDEBAR: state => {SET_TABLE_FONT_SIZE: (state, fontSize) => {state.tableFontSize = fontSizeCookies.set('tableFontSize', fontSize)}}
}// 在app.js中的代码
const state = {tableFontSize: Cookies.get('tableFontSize') || window.getComputedStyle(document.documentElement).getPropertyValue('--table-font-size')
}

总结

作为一个常年写java代码的开发人员真的感觉css出神入化,之前还停留在css只能写静态属性的印象中,没想到已经这么方便

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 深度学习实践:理解理论背后的机制,体会理论与实际应用中的差距
  • 如何编写Prompt,利用AI高效生成图表——图表狐(FoxChart)指南
  • 设计模式-行为型模式-备忘录模式
  • Vue3如何查看项目是否安装了vue-router路由依赖,及安装方法
  • 数据结构与算法-17高级数据结构_图论(迪杰斯特拉算法)
  • 《黑神话:悟空》本地存档误删了怎么恢复?三种方法!
  • PHP7 json_encode() 浮点小数溢出错误
  • 攻防世界 ics-05
  • 【原创】java+swing+mysql项目管理系统设计与实现
  • OPENAIGC开发者大赛高校组银奖 | LonAC中小学编程学习平台
  • 借助MoAiStudio不写一行代码,完成页面开发
  • Redis的IO模型
  • 如何使用UWA Gears连接模拟器进行性能测试
  • Spring部分常见面试题
  • 记录k8s重启之后kubelet无法启动的问题
  • [译]Python中的类属性与实例属性的区别
  • 03Go 类型总结
  • Bytom交易说明(账户管理模式)
  • java多线程
  • maven工程打包jar以及java jar命令的classpath使用
  • Vue2 SSR 的优化之旅
  • vue--为什么data属性必须是一个函数
  • webpack+react项目初体验——记录我的webpack环境配置
  • Web设计流程优化:网页效果图设计新思路
  • windows下mongoDB的环境配置
  • 第13期 DApp 榜单 :来,吃我这波安利
  • 多线程 start 和 run 方法到底有什么区别?
  • 分布式事物理论与实践
  • 分享一个自己写的基于canvas的原生js图片爆炸插件
  • 全栈开发——Linux
  • 说说动画卡顿的解决方案
  • 微服务核心架构梳理
  • 微信支付JSAPI,实测!终极方案
  • 中文输入法与React文本输入框的问题与解决方案
  • 蚂蚁金服CTO程立:真正的技术革命才刚刚开始
  • 移动端高清、多屏适配方案
  • ​力扣解法汇总946-验证栈序列
  • ​云纳万物 · 数皆有言|2021 七牛云战略发布会启幕,邀您赴约
  • #HarmonyOS:基础语法
  • #if 1...#endif
  • #QT项目实战(天气预报)
  • (14)学习笔记:动手深度学习(Pytorch神经网络基础)
  • (C++)八皇后问题
  • (poj1.3.2)1791(构造法模拟)
  • (代码示例)使用setTimeout来延迟加载JS脚本文件
  • (一) springboot详细介绍
  • (转)linux 命令大全
  • (转)负载均衡,回话保持,cookie
  • (自适应手机端)响应式服装服饰外贸企业网站模板
  • *1 计算机基础和操作系统基础及几大协议
  • .apk 成为历史!
  • .Net Core 中间件验签
  • .NET MAUI Sqlite程序应用-数据库配置(一)
  • .NET Standard 支持的 .NET Framework 和 .NET Core
  • .NET处理HTTP请求