前端基础学习-动态改变样式

动态改变样式

曾经遇到过的一点小问题,小小的记录一下
这里变更的样式是表单的必填项*的位置

先看一下效果
在这里插入图片描述
在我们点击button‘更换*位置时’
在这里插入图片描述
可以看到必填校验的星移动到了右边

首先看一下这个必填项*的样式是怎么写的
引用element-ui,可以看到初始样式
在这里插入图片描述
我们如果需要改变这个样式只需要将before的content置空,在after后写上对应样式即可

  .el-form-item.is-required:not(.is-no-asterisk) .el-form-item__label-wrap>.el-form-item__label:before, .el-form-item.is-required:not(.is-no-asterisk)>.el-form-item__label:before {
    content: '';
  }
  .el-form-item.is-required:not(.is-no-asterisk) .el-form-item__label-wrap>.el-form-item__label:before, .el-form-item.is-required:not(.is-no-asterisk)>.el-form-item__label::after {
    content: '*';
    color: #F56C6C;
    margin-left: 4px;
  }

在这里,我们通过按钮动态控制这个样式
1、在el-form中动态绑定class

 <el-form :model="ruleForm" :rules="rules" ref="ruleForm" :class="changeStar ? '' : 'after'" label-width="100px" style="width: 85%;">
 </el-form>

根据changeStar决定使用哪种样式,由于element-ui自带样式,所以我不做更改,我更改的样式为after
2、点击事件切换changeStar

<el-button @click="changeStyle">更换*位置</el-button>

method

    changeStyle () {
      this.changeStar = !this.changeStar
    }

3、添加after样式

<style lang="scss">
.after {
  .el-form-item.is-required:not(.is-no-asterisk) .el-form-item__label-wrap>.el-form-item__label:before, .el-form-item.is-required:not(.is-no-asterisk)>.el-form-item__label:before {
    content: '';
  }
  .el-form-item.is-required:not(.is-no-asterisk) .el-form-item__label-wrap>.el-form-item__label:before, .el-form-item.is-required:not(.is-no-asterisk)>.el-form-item__label::after {
    content: '*';
    color: #F56C6C;
    margin-left: 4px;
  }
}
</style>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值