vue2,style标签中引用data变量

需求:点击放大缩小按钮,动态改变el-form所有label和content部分的字体大小。

因为我们要修改的样式是el-form的子元素el-form-item的label和content的字体大小,要先给el-form绑定计算属性return一个变量A,再通过按钮动态改变字体大小。再style中通过通过var()关键字,使用--符号引用变量A。

javascript 复制代码
<div>
    <i class="el-icon-zoom-in" @click="zoomIn"></i>
    <i class="el-icon-zoom-out" @click="zoomOut"></i>
</div>
<div class="box1">
    <el-form ref="form" label-width="140px" label-position="left" :style="fontSizeVar">
                <el-form-item label="类型:">{{
                  curRow.type
                }}</el-form-item>
                <el-form-item label="位置:">{{
                  curRow.position
                }}</el-form-item>
    </el-form>
</div>


data(){
    return {
      fontSize :14
    }
},
computed:{
    fontSizeVar(){
      return {
        '--fontsize':this.fontSize + 'px'
      }
    },
}

methods:{
    zoomIn(){
        if(this.fontSize < 24){
            this.fontSize  += 2
          }
    },
    zoomOut(){
        if(this.fontSize > 14){
            this.fontSize -= 2
          }
    },
}

style样式:使用var调用data中的变量
       .box1{
          ::v-deep .el-form-item__label{
            font-size: var(--fontsize);
          }
          ::v-deep .el-form-item__content{
            font-size: var(--fontsize);
          }
          .el-button{
            font-size: var(--fontsize);
          }
        }
相关推荐
ziyue757519 分钟前
vue修改element-ui的默认的class
前端·vue.js·ui
树叶会结冰40 分钟前
HTML语义化:当网页会说话
前端·html
冰万森1 小时前
解决 React 项目初始化(npx create-react-app)速度慢的 7 个实用方案
前端·react.js·前端框架
牧羊人_myr1 小时前
Ajax 技术详解
前端
浩男孩1 小时前
🍀封装个 Button 组件,使用 vitest 来测试一下
前端
蓝银草同学1 小时前
阿里 Iconfont 项目丢失?手把手教你将已引用的 SVG 图标下载到本地
前端·icon
布列瑟农的星空1 小时前
重学React —— React事件机制 vs 浏览器事件机制
前端
程序定小飞2 小时前
基于springboot的在线商城系统设计与开发
java·数据库·vue.js·spring boot·后端
一小池勺2 小时前
CommonJS
前端·面试