vue如何动态设置class、动态设置style

 更新时间:2022年10月17日 10:19:34   作者:徐_三岁  
这篇文章主要介绍了vue如何动态设置class、动态设置style,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

vue动态设置class、style

//动态class对象
<div :class="{ 'isActive': true, 'red': isRed }"></div>
//动态style对象
<div :style="{ color: bgColor, fontSize: '18px' }"></div>
//动态class数组
<div :class="['is-active', isRed ? 'red' : '' ]"></div>
//动态style数组
<div :style="[{ color: bgColor, fontSize: '18px' }, { fontWeight: '500' }]"></div>

vue动态添加样式 :style 和 :class

动态添加可以采用:class  也可以采用:style

但是在一个长期维护的项目里面:style行内样式尽量避免。 

<template>
    <div>
        <h2>动态添加类名</h2>
        <!-- 第一种方式:对象的形式 -->
        <!-- 第一个参数 类名, 第二个参数:boolean值 -->
        <!-- 对象的形式: 用花括号包裹起来,类名用引号, -->
        <!-- 优点: 以对象的形式可以写多个,用逗号分开 -->
        <p :class="{'sm' : true}">对象的形式</p>
        <p :class="{'sm' : false, 'lg': true}">对象的形式</p>
 
        <!-- 第二种方式:三元表达式 注意点:放在数组中,类名要用引号-->
        <p :class="[ controller.summary? 'sm' : 'lg' ]" >三元表示式</p>
 
        <!-- 第三种方式: 数组的形式 -->
        <p :class="[isTrue, isFalse]">数组的形式</p>
 
        <!-- 数组中用对象 -->
        <p :class="[{'sm': false}, isFalse]">数组中使用对象</p>
 
        <!--补充:  class中还可以传方法,在方法中返回类名-->
        <p :class="setClass">通过方法设置class类名</p>
    </div>
 
    //-选中的一项更换背景色,其余兄弟元素没有背景色
    <ul class="options-box">
       <li v-for="(item,index) in hours" 
           :key="index" @click="selectHour(item,index)" 
           :class="{selected:readySelectHour === index}">
           <span>{{item.name}}</span>
       </li>
    </ul>
</template>
<script>
    export default {
        data () {
           return {
               isTrue: 'sm',
               isFalse: 'lg'
           };
        },
 
  method: {
     setclass () {
        return 'sm';
      },
      selectHour(itemhour,index){
          this.hour = itemhour.name;
          this.readySelectHour = index;       
      },
 
  }
}
</script>
<style scoped>
    .sm {
        padding-top:10px;
    }
    .lg {
       padding-top:20px;
    }
 
li{
    text-align: center;
    line-height: 32px;
    font-size: 12px;
   &:hover {
       background-color:#f8f9fa;
    }
  &.selected{
        background-color: #e6fff7;
  }
 }
</style>

其次还可以用 :style

给一个div动态添加padding-top  我们可以用上面的:class方法  也可以用:style 的方法

还是以上面的class样式为例

:style如下

<div class="controller" :style="{paddingTop:controller.summary?'20px':'10px'}"></div>

:class如下 

<div class="controller" :class="[controller.summary? 'lg':'sm']"></div>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue打包生成的文件的js文件过大的优化方式

    vue打包生成的文件的js文件过大的优化方式

    这篇文章主要介绍了vue打包生成的文件的js文件过大的优化方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue引入并使用Element组件库的两种方式小结

    Vue引入并使用Element组件库的两种方式小结

    本文主要介绍了Vue引入并使用Element组件库的两种方式小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • vue+render+jsx实现可编辑动态多级表头table的实例代码

    vue+render+jsx实现可编辑动态多级表头table的实例代码

    这篇文章主要介绍了vue+render+jsx实现可编辑动态多级表头table的实例代码,本文通过实例代码给大家介绍的非常详细,对大家的工作或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-04-04
  • 使用vue打包进行云服务器上传的问题

    使用vue打包进行云服务器上传的问题

    这篇文章主要介绍了使用vue打包进行云服务器上传,本文给大家介绍的非常详细,对大家的工作或学习具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • vue、uniapp实现组件动态切换效果

    vue、uniapp实现组件动态切换效果

    在Vue中,通过使用动态组件,我们可以实现组件的动态切换,从而达到页面的动态展示效果,这篇文章主要介绍了vue、uniapp实现组件动态切换,需要的朋友可以参考下
    2023-10-10
  • vue引用js文件的多种方式(推荐)

    vue引用js文件的多种方式(推荐)

    这篇文章主要介绍了vue引用js文件的多种方式,本文大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-05-05
  • 深入浅出分析vue2和vue3的区别

    深入浅出分析vue2和vue3的区别

    这篇文章主要介绍了vue2和vue3的区别,较为详细的分析了vue2与vue3的常见区别与使用方法,需要的朋友可以参考下
    2023-06-06
  • Vue2.0基于vue-cli+webpack父子组件通信(实例讲解)

    Vue2.0基于vue-cli+webpack父子组件通信(实例讲解)

    下面小编就为大家带来一篇Vue2.0基于vue-cli+webpack父子组件通信(实例讲解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • 在uniapp中实现图形验证码的详细步骤

    在uniapp中实现图形验证码的详细步骤

    图形验证码是一种常见的安全措施,用于防止自动化软件(机器人)滥用网站资源,如自动提交表单,这篇文章主要介绍了在uniapp中实现图形验证码的详细步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-11-11
  • vue.js实现的经典计算器/科学计算器功能示例

    vue.js实现的经典计算器/科学计算器功能示例

    这篇文章主要介绍了vue.js实现的经典计算器/科学计算器功能,具有基本四则运算计算器以及科学计算器的功能,可实现开方、乘方、三角函数以及公式运算等功能,需要的朋友可以参考下
    2018-07-07

最新评论