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中ref和$refs获取元素dom、获取子组件数据与方法调用示例

    vue中ref和$refs获取元素dom、获取子组件数据与方法调用示例

    在Vue3中要获取子组件的DOM节点,你可以使用ref来引用子组件,然后通过$refs来访问子组件的DOM,下面这篇文章主要给大家介绍了关于vue中ref和$refs获取元素dom、获取子组件数据与方法调用的相关资料,需要的朋友可以参考下
    2024-07-07
  • 浅谈vue权限管理实现及流程

    浅谈vue权限管理实现及流程

    这篇文章主要介绍了浅谈vue权限管理实现及流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • vue后端传文件流转化成blob对象,前端点击下载返回undefined问题

    vue后端传文件流转化成blob对象,前端点击下载返回undefined问题

    这篇文章主要介绍了vue后端传文件流转化成blob对象,前端点击下载返回undefined问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • vue3.2 Composition API项目依赖升级

    vue3.2 Composition API项目依赖升级

    这篇文章主要为大家介绍了vue3.2 Composition API项目依赖升级示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • vue 使用 vue-pdf 实现pdf在线预览的示例代码

    vue 使用 vue-pdf 实现pdf在线预览的示例代码

    这篇文章主要介绍了vue 使用 vue-pdf 实现pdf在线预览的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • Vue精美简洁登录页完整代码实例

    Vue精美简洁登录页完整代码实例

    这篇文章主要给大家介绍了关于Vue精美简洁登录页完整代码的相关资料,通过文中的方法大家可以使用实现简单的用户登录界面,下面通过示例代码介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • vue1.0和vue2.0的watch监听事件写法详解

    vue1.0和vue2.0的watch监听事件写法详解

    今天小编就为大家分享一篇vue1.0和vue2.0的watch监听事件写法详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • el-table 树形数据 tree-props 多层级使用避坑

    el-table 树形数据 tree-props 多层级使用避坑

    本文主要介绍了el-table 树形数据 tree-props 多层级使用避坑,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-08-08
  • Vue DevTools调试工具的使用

    Vue DevTools调试工具的使用

    本篇文章主要介绍了Vue DevTools调试工具的使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-12-12
  • vue el-select绑定对象时,回显内容不正确,始终是最后一项的解决

    vue el-select绑定对象时,回显内容不正确,始终是最后一项的解决

    这篇文章主要介绍了vue el-select绑定对象时,回显内容不正确,始终是最后一项的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07

最新评论