Web前端开发之VUE08——动态class的优化、props验证

本文探讨了如何在Vue中通过data对象动态管理class属性,解决长属性问题,并介绍如何结合使用类名和对象来控制样式。同时,关注了props验证在组件通信中的应用,确保组件间数据的有效传递。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

动态class的优化:

Class值与Class对象同时使用:

props验证:


动态class的优化:

在往期的class中我们会使用对象键值对直接输入在标签上,这样会使属性过长。

使用data的对象传入是一个不错的解决办法。

示例代码:

style操作过程中发现animation不能被编译,貌似是因为vue给class动态绑定了哈希,但是style动态没有绑定哈希导致的。

 下面看一个示例:

<template>
  <div>
    <div class="text" :class="textAnimStyle">我是一段文字,我使用class</div>
    <button @click="animateToggle('rotate360')">旋转</button>
    <button @click="animateToggle('scaleIt')">放大</button>
    <div class="text" :style="textStyle">我是另一段文字,我使用style</div>

  </div>

</template>

<script>
export default {
  name: "MyApp",
  data() {
    return {
      textAnimStyle: {
        rotate360:false,
        scaleIt:false
      },
      textStyle:{
        'font-size':20+'px',
        //下面的代码不生效
        'animation':'rotate360 2s alternate infinite',
      }
    }
  },
  methods:{
    animateToggle(animateType){
      for (const ele in this.textAnimStyle) {
        this.textAnimStyle[ele]=false
      }
      for (const ele in this.textAnimStyle) {
        if (ele===animateType){
          this.textAnimStyle[ele]=true
        }
      }
    },
  }
}
</script>

<style scoped>
.text {
  display: inline-block;
  transform-origin: center;
}
.rotate360{
  animation: rotate360 2s alternate infinite;
}
.scaleIt{
  animation: scaleIt 2s alternate infinite;
}

@keyframes rotate360 {
  from {
  }
  to {
    transform: rotateZ(360deg);
  }
}

@keyframes scaleIt {
  from {
  }
  to {
    transform: scale(1.5);
  }
}

</style>

Class值与Class对象同时使用:

:class="[navElemClass,{isSelected:item.isSelected}]"

props验证:

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

言行物恒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值