vue3-类与样式绑定

Class 与 Style 绑定

  1. class 和 style 都是 attribute,我们可以和其他 attribute 一样使用 v-bind 将它们和动态的字符串绑定。

  2. Vue 专门为 class 和 style 的 v-bind 用法提供了特殊的功能增强。除了字符串外,表达式的值也可以是对象或数组。

绑定class

  1. :class (v-bind:class 的缩写) 传递一个对象来动态切换 class

  2. class 指令也可以和一般的 class 属性 共存。

  3. 绑定的对象并不一定需要写成内联字面量的形式,也可以直接绑定一个对象


import { ref } from "vue"

const isActive = ref(true)
const hasError = ref(false)

const classObject = reactive({
    active: true,
    'text-danger': false
})





.container {}

绑定数组

我们可以给 :class 绑定一个数组来渲染多个 CSS class

  1. 直接绑定数组

  2. 数组中使用三元表达式

  3. 数组中嵌套对象(看着简洁)


import { ref } from "vue"

const isActive = ref(true)

const activeClass = ref('active')
const errorClass = ref('text-danger')




.container {}

在组件上使用

  • 对于只有一个根元素的组件,当你使用了 class attribute 时,这些 class 会被添加到根元素上并与该元素上已有的 class 合并。

  • 组件模版


Hi!

在使用时添加一些 class:



渲染出的 HTML 为:

Hi!

Class 的绑定也是同样的效果



Hi!

绑定内联样式

绑定对象

  1. :style 支持绑定 JavaScript 对象值,对应的是 HTML 元素的 style 属性:

const activeColor = ref('red')
const fontSize = ref(30)

  1. 尽管推荐使用 camelCase,但 :style 也支持 kebab-cased 形式的 CSS 属性 key (对应其 CSS 中的实际名称),例如:

  1. 直接绑定一个样式对象通常是一个好主意,这样可以使模板更加简洁

const styleObject = reactive({
  color: 'red',
  fontSize: '13px'
})

同样的,如果样式对象需要更复杂的逻辑,也可以使用返回样式对象的计算属性。

绑定数组

我们还可以给 :style 绑定一个包含多个样式对象的数组。这些对象会被合并后渲染到同一元素上:

自动前缀

当你在 :style 中使用了需要浏览器特殊前缀的 CSS 属性时,Vue 会自动为他们加上相应的前缀。Vue 是在运行时检查该属性是否支持在当前浏览器中使用。如果浏览器不支持某个属性,那么将尝试加上各个浏览器特殊前缀,以找到哪一个是被支持的。

样式多值 你可以对一个样式属性提供多个 (不同前缀的) 值,举例来说:

数组仅会渲染浏览器支持的最后一个值。在这个示例中,在支持不需要特别前缀的浏览器中都会渲染为 display: flex。

你可能感兴趣的:(vue3,javascript,vue.js,前端)