vue、uniapp中动态添加绑定style、class 9种实现方法

 更新时间:2023年09月02日 10:34:58   作者:一花一world  
这篇文章主要介绍了vue、uniapp中动态添加绑定style、class 9种方法实现,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

9种方法介绍

1.直接使用静态class和style属性:

  • 使用场景:当class和style属性是固定不变的时候,可以直接在模板中写死。
  • 优点:简单直接,没有额外的计算和逻辑。
  • 缺点:无法根据条件动态修改class和style。

2.使用v-bind动态绑定class和style属性:

  • 使用场景:当class和style属性需要根据组件的data或props属性动态变化时,可以使用v-bind来动态绑定。
  • 优点:可以根据条件动态修改class和style。
  • 缺点:需要在模板中写表达式,有一定的复杂度。

3.使用计算属性来动态生成class和style对象:

  • 使用场景:当class和style属性的计算逻辑比较复杂时,可以使用计算属性来生成class和style对象。
  • 优点:代码可读性好,逻辑清晰。
  • 缺点:需要定义额外的计算属性。

4.使用动态绑定的class和style属性:

  • 使用场景:当class和style属性的计算逻辑比较简单时,可以直接在模板中使用表达式来动态生成class和style字符串。
  • 优点:简洁明了,没有额外的计算属性。
  • 缺点:逻辑稍微复杂时,可读性会变差。

5.使用数组语法来动态绑定class属性:

  • 使用场景:当class属性需要根据多个条件动态变化时,可以使用数组语法来动态绑定class属性。
  • 优点:可以根据多个条件动态修改class。
  • 缺点:数组语法相对复杂,可读性较差。

6.使用动态绑定的style属性:

  • 使用场景:当style属性需要根据组件的data或props属性动态变化时,可以使用动态绑定的style属性。
  • 优点:可以根据条件动态修改style。
  • 缺点:需要在模板中写表达式,有一定的复杂度。

7.使用对象语法动态绑定class属性:

  • 使用场景:当class属性需要根据多个条件动态变化时,可以使用对象语法来动态绑定class属性。
  • 优点:可以根据多个条件动态修改class。
  • 缺点:对象语法相对复杂,可读性较差。

8.使用计算属性动态绑定style属性:

  • 使用场景:当style属性的计算逻辑比较复杂时,可以使用计算属性来动态绑定style属性。
  • 优点:代码可读性好,逻辑清晰。
  • 缺点:需要定义额外的计算属性。

9.使用动态绑定的class和style属性,通过在模板中使用数组和对象语法来动态生成class和style字符串:

  • 使用场景:当class和style属性需要根据多个条件动态变化时,可以使用数组和对象语法来动态绑定class和style属性。
  • 优点:可以根据多个条件动态修改class和style。
  • 缺点:语法相对复杂,可读性较差。

具体实现

在Uniapp和Vue中,可以使用以下9种方法来动态添加绑定style和class:

1.使用v-bind指令(或简写为:class:style)来动态绑定class和style属性。可以通过计算属性或直接在模板中使用三元表达式来根据条件动态设置class和style属性。

<template>
  <div :class="{'active': isActive}" :style="{'color': textColor}">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      isActive: true,
      textColor: 'red'
    }
  }
}
</script>

2.使用v-bind指令(或简写为:class:style)来动态绑定class和style对象。可以在data中定义一个对象,根据条件动态设置class和style对象的属性。

<template>
  <div :class="classObject" :style="styleObject">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      classObject: {
        active: true,
        'text-color': true
      },
      styleObject: {
        color: 'red',
        fontSize: '16px'
      }
    }
  }
}
</script>

3.使用计算属性来动态生成class和style对象。可以根据组件的data或props属性计算出class和style对象,并在模板中使用计算属性。

<template>
  <div :class="computedClass" :style="computedStyle">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      isActive: true,
      textColor: 'red'
    }
  },
  computed: {
    computedClass() {
      return {
        active: this.isActive,
        'text-color': this.textColor === 'red'
      }
    },
    computedStyle() {
      return {
        color: this.textColor,
        fontSize: '16px'
      }
    }
  }
}
</script>

4.使用动态绑定的class和style属性,通过在模板中使用表达式来动态生成class和style字符串。

<template>
  <div :class="'active ' + (isActive ? 'active' : '')" :style="'color: ' + textColor">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      isActive: true,
      textColor: 'red'
    }
  }
}
</script>

5.使用数组语法来动态绑定class属性。可以在data中定义一个数组,根据条件动态设置class数组的元素。

<template>
  <div :class="classArray">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      isActive: true,
      isBold: true
    }
  },
  computed: {
    classArray() {
      return ['active', {'bold': this.isBold}]
    }
  }
}
</script>

6.使用动态绑定的style属性,通过在模板中使用对象语法来动态生成style字符串。

<template>
  <div :style="{ color: textColor, fontSize: fontSize + 'px' }">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      textColor: 'red',
      fontSize: 16
    }
  }
}
</script>

7.使用对象语法动态绑定class属性。可以在data中定义一个对象,根据条件动态设置class对象的属性。

<template>
  <div :class="classObject">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      isActive: true,
      isBold: true
    }
  },
  computed: {
    classObject() {
      return {
        active: this.isActive,
        bold: this.isBold
      }
    }
  }
}
</script>

8.使用计算属性动态绑定style属性。可以根据组件的data或props属性计算出style字符串,并在模板中使用计算属性。

<template>
  <div :style="computedStyle">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      textColor: 'red',
      fontSize: 16
    }
  },
  computed: {
    computedStyle() {
      return `color: ${this.textColor}; font-size: ${this.fontSize}px;`;
    }
  }
}
</script>

9.使用动态绑定的class和style属性,通过在模板中使用数组和对象语法来动态生成class和style字符串。

<template>
  <div :class="['active', { 'bold': isBold }]">Hello World</div>
  <div :style="[styleObject, { 'font-size': fontSize + 'px' }]">Hello World</div>
</template>
<script>
export default {
  data() {
    return {
      isBold: true,
      styleObject: {
        color: 'red'
      },
      fontSize: 16
    }
  }
}
</script>

到此这篇关于vue、uniapp中动态添加绑定style、class 9种方法实现的文章就介绍到这了,更多相关uniapp动态绑定style、class内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 谈一谈vue请求数据放在created好还是mounted里好

    谈一谈vue请求数据放在created好还是mounted里好

    这篇文章主要介绍了谈一谈vue请求数据放在created好还是mounted里好的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • vue复合组件实现注册表单功能

    vue复合组件实现注册表单功能

    这篇文章主要为大家详细介绍了vue复合组件实现注册表单功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Element Table的row-class-name无效与动态高亮显示选中行背景色

    Element Table的row-class-name无效与动态高亮显示选中行背景色

    这篇文章主要介绍了Element Table的row-class-name无效与动态高亮显示选中行背景色,本文详细的介绍了解决方案,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • vue实现tab切换的3种方式及切换保持数据状态

    vue实现tab切换的3种方式及切换保持数据状态

    这篇文章主要给大家介绍了关于vue实现tab切换的3种方式及切换保持数据状态的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • 强制Vue重新渲染组件的5种方法小结

    强制Vue重新渲染组件的5种方法小结

    在开发Vue.js应用程序时,有时我们需要强制重新渲染组件以确保数据和视图同步,下面就来介绍一下强制Vue重新渲染组件的5种方法,感兴趣的可以了解一下
    2025-06-06
  • 解决vue无法加载文件D:\Program Files\nodejs\node_global\vue.ps1,因为在此系统上禁止运行脚本

    解决vue无法加载文件D:\Program Files\nodejs\node_global\vue.ps1,

    这篇文章主要给大家介绍了关于解决vue无法加载文件D:\Program Files\nodejs\node_global\vue.ps1,因为在此系统上禁止运行脚本的相关资料,这个报错是由于在系统上禁止运行脚本导致的,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • iview实现动态表单和自定义验证时间段重叠

    iview实现动态表单和自定义验证时间段重叠

    这篇文章主要介绍了iview实现动态表单和自定义验证时间段重叠,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • uniapp+vue3实现上传图片组件封装功能

    uniapp+vue3实现上传图片组件封装功能

    这篇文章主要介绍了uniapp+vue3实现上传图片组件封装功能,首先创建一个 components 文件在里面进行组件的创建,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2024-07-07
  • Vue3实现动态导入Excel表格数据的方法详解

    Vue3实现动态导入Excel表格数据的方法详解

    在开发工作过程中,我们会遇到各种各样的表格数据导入,动态数据导入可以减少人为操作,减少出错。本文为大家介绍了Vue3实现动态导入Excel表格数据的方法,需要的可以参考一下
    2022-11-11
  • 详解vue 自定义组件使用v-model 及探究其中原理

    详解vue 自定义组件使用v-model 及探究其中原理

    这篇文章主要介绍了详解vue 自定义组件使用v-model 及探究其中原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10

最新评论