Vue通过js控制css变量一键修改全局样式的完整过程

 更新时间:2025年05月20日 10:38:44   投稿:daisy  
这篇文章主要介绍了Vue通过js控制css变量一键修改全局样式的完整过程,结合ElementUI、vuex和cookie保存用户设置,确保表格字体随滚动条变化且新页面同步生效,提升样式维护灵活性,需要的朋友可以参考下

背景

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

需求整理

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

实现效果如图:

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

系统现状

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

实现思路

  • ElementUI有个控制全局大小的size变量,只要使用的控件不添加size属性,就会读取全局的size变量进行相应大小的展示。
    • 但该设置只能设置为预设的4种大小(defaultmeduimsmallmini)无法满足需求中的设置字体大小为指定像素(px)。
  • 通过修改全局样式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.$route
    this.$nextTick(() => {
      this.$router.replace({
        path: '/redirect' + fullPath
      })
    })
  }
}

// 在vuex中的代码
const mutations = {
  TOGGLE_SIDEBAR: state => {
    SET_TABLE_FONT_SIZE: (state, fontSize) => {
      state.tableFontSize = fontSize
      Cookies.set('tableFontSize', fontSize)
    }
  }
}

// 在app.js中的代码
const state = {
  tableFontSize: Cookies.get('tableFontSize') || window.getComputedStyle(document.documentElement).getPropertyValue('--table-font-size')
}

总结

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

到此这篇关于Vue通过js控制css变量一键修改全局样式的文章就介绍到这了,更多相关Vue通过js控制css变量内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决vuejs 使用value in list 循环遍历数组出现警告的问题

    解决vuejs 使用value in list 循环遍历数组出现警告的问题

    今天小编就为大家分享一篇解决vuejs 使用value in list 循环遍历数组出现警告的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • vue使用拖拽方式创建结构树

    vue使用拖拽方式创建结构树

    这篇文章主要为大家详细介绍了vue使用拖拽方式创建结构树,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • element修改form的el-input宽度,el-select宽度的方法实现

    element修改form的el-input宽度,el-select宽度的方法实现

    有时候像form表单这样,页面的input、select等宽度不一定会是一样的,可能有些长,有些短,本文就介绍了如何element修改form的el-input宽度,el-select宽度的方法实现,感兴趣的可以了解一下
    2022-02-02
  • idea部署RuoYi-Vue分离版的图文详解

    idea部署RuoYi-Vue分离版的图文详解

    RuoYi-Vue是一款基于SpringBoot+Vue的前后端分离极速后台开发框架, 本文主要介绍了idea部署RuoYi-Vue分离版的图文详解,具有一定的参考价值,感兴趣的可以了解一下
    2024-06-06
  • 简单聊聊vue2.x的$attrs和$listeners

    简单聊聊vue2.x的$attrs和$listeners

    vue组件之间的通信方式有很多种,props/emit,event bus,vuex,provide/inject等,还有一种通信方式就是$attrs和$listeners,下面这篇文章主要给大家介绍了关于vue2.x中$attrs和$listeners的相关资料,需要的朋友可以参考下
    2022-03-03
  • Vue使用distpicker插件实现省市级下拉框三级联动

    Vue使用distpicker插件实现省市级下拉框三级联动

    这篇文章主要介绍了Vue使用distpicker插件实现省市级下拉框三级联动,比如通过JSON文件生成对应的区域下拉框,element-china-are插件,包括distpicker插件,通过代码讲解如何使用distpicker插件实现省市级三联跳动,需要的朋友可以参考下
    2023-02-02
  • vue中this.$router.push()路由传值和获取的两种常见方法汇总

    vue中this.$router.push()路由传值和获取的两种常见方法汇总

    这篇文章主要介绍了vue中this.$router.push()路由传值和获取的两种常见方法,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-12
  • vue使用@scroll监听滚动事件时,@scroll无效问题的解决方法详解

    vue使用@scroll监听滚动事件时,@scroll无效问题的解决方法详解

    这篇文章主要介绍了vue使用@scroll监听滚动事件时,@scroll无效问题的解决方法,结合实例形式分析了@scroll监听滚动事件无效问题的原因及相应的解决方法,需要的朋友可以参考下
    2019-10-10
  • Vue组件传值过程接收不成功的问题及解决

    Vue组件传值过程接收不成功的问题及解决

    这篇文章主要介绍了Vue组件传值过程接收不成功的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • Vue+ElementUI启动vue卡死的问题及解决

    Vue+ElementUI启动vue卡死的问题及解决

    这篇文章主要介绍了Vue+ElementUI启动vue卡死的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03

最新评论