vue3-类与样式绑定

这篇具有很好参考价值的文章主要介绍了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. 绑定的对象并不一定需要写成内联字面量的形式,也可以直接绑定一个对象

<script lang="ts" setup>
import { ref } from "vue"

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

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

</script>

<template>
    <div class="container">
        <div class="static" :class="{ active: isActive, 'text-danger': hasError }"></div>
        <!-- 输出为 -->
        <!-- <div class="static active"></div> -->

        <div :class="classObject"></div>
        <!-- 输出为 -->
        <!-- <div class="active"></div> -->
    </div>
</template>

<style lang="scss" scoped>
.container {}
</style>

绑定数组

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

  1. 直接绑定数组

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

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

<script lang="ts" setup>
import { ref } from "vue"

const isActive = ref(true)

const activeClass = ref('active')
const errorClass = ref('text-danger')
</script>

<template>
    <div class="container">
        <!-- 直接绑定一个类名 -->
        <div :class="activeClass"></div>

        <!-- 在数组中可以传入多个类名 -->
        <div :class="[activeClass, errorClass]"></div>

        <!-- 渲染结果 -->
        <!-- <div class="active text-danger">111</div> -->

        <!-- 三元表达式 -->
        <div :class="[isActive ? activeClass : '', errorClass]">222</div>

        <!-- 数组中嵌套对象 -->
        <div :class="[{ active: isActive }, errorClass]">333</div>
    </div>
</template>

<style lang="scss" scoped>
.container {}
</style>

在组件上使用

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

  • 组件模版

<!-- 子组件模板 -->
<p class="foo bar">Hi!</p>

在使用时添加一些 class:

<!-- 在使用组件时 -->
<MyComponent class="baz boo" />

渲染出的 HTML 为:

<p class="foo bar baz boo">Hi!</p>

Class 的绑定也是同样的效果

<MyComponent :class="{ active: isActive }" />

<p class="foo bar active">Hi!</p>

绑定内联样式

绑定对象

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

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

<div :style="{ color: activeColor, fontSize: fontSize + 'px' }"></div>
  1. 尽管推荐使用 camelCase,但 :style 也支持 kebab-cased 形式的 CSS 属性 key (对应其 CSS 中的实际名称),例如:

<div :style="{ 'font-size': fontSize + 'px' }"></div>
  1. 直接绑定一个样式对象通常是一个好主意,这样可以使模板更加简洁

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

<div :style="styleObject"></div>

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

绑定数组

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

<div :style="[baseStyles, overridingStyles]"></div>

自动前缀

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

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

<div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }"></div>

数组仅会渲染浏览器支持的最后一个值。在这个示例中,在支持不需要特别前缀的浏览器中都会渲染为 display: flex。文章来源地址https://www.toymoban.com/news/detail-803228.html

到了这里,关于vue3-类与样式绑定的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Vue2和vue3中双向数据绑定的原理,ES6的Proxy对象代理和JavaScript的Object.defineProperty,使用详细

    简介: Object.defineProperty大家都知道,是vue2中双向数据绑定的原理,它 是 JavaScript 中一个强大且常用的方法,用于定义对象属性,允许我们精确地控制属性的行为,包括读取、写入和删除等操作; 而Proxy是vue3中双向数据绑定的原理,是ES6中一种用于创建代理对象的特殊对象,

    2024年02月15日
    浏览(47)
  • 前端技术Html,Css,JavaScript,Vue3

    1.基本标签 2.文本格式化 3.链接 4.图片 5.无序列表 6.有序列表 7.表格 8.表单 1.选择器 2.文本和字体 3.链接 4.隐藏 5.定位position 6.浮动 7.对齐 8.图像 1.输出 2.函数 3.常用事件 4.DOM 5.改变Html 6.DOM 元素 (节点) 尾部创建新的 HTML 元素 (节点) - appendChild() 头部创建新的 HTML 元素 (节点)

    2024年02月13日
    浏览(53)
  • 【前端技术】Vue3 01:初识 Vue.js

    Vue 可以说是非常流行了,至少在国内是这样,他是个轻量级的 JavaScript 框架,非常适合构建大型和中小型的 Web 应用程序,如果想和前端打交道,应该绕不过这个框架吧。 目录 1 Vue.js 介绍 2  IDE 选择 2.1 vscode 2.2 WebStorm 2.3 Eclipse 3  创建 Vue 应用 3.1 本地脚手架创建 ① 安装

    2024年02月02日
    浏览(64)
  • 前端(四)——vue.js、vue、vue2、vue3

    😊博主:小猫娃来啦 😊文章核心: vue.js、vue、vue2、vue3从全局到局部 Vue.js是一款流行的JavaScript框架 vue,vue2,vue3都是vue.js的不同版本。 Vue:Vue.js的第一个版本,也称为Vue 1.x。它于2014年首次发布,并获得了广泛的应用和认可。 Vue2:Vue.js的第二个版本,也称为Vue 2.x。它在Vu

    2024年02月12日
    浏览(79)
  • 前端HTML、CSS、JS、VUE3 汇总

    学习https://developer.mozilla.org/zh-CN/docs/Learn/CSS 提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加 使用VS Code运行前端代码 在VS Code上安装前端插件 正在更新中~ ✨ 提示:这里可以添加本文要记录的大概内容: 学习路线 知识定位 HTML基础 标签、表格、表单、

    2024年02月13日
    浏览(51)
  • web前端框架设计第六课-样式绑定

    1.class属性绑定 给P标签绑定一个类样式,类名为active。当active取值为true时,表示绑定样式成功,取值为false时,取消绑定 以对象形式给P标签绑定多个类样式 以数组形式给P标签绑定多个类样式 2.内联样式绑定(见书P66) –行动是治愈恐惧的良药,犹豫拖延将不断滋养恐惧

    2024年04月28日
    浏览(29)
  • 【Vue】学习笔记-绑定样式/条件样式

    class样式 写法 :class=\\\"xxx\\\" xxx可以是字符串,对象,数组 字符串写法适用于:类名不确定,要动态获取。 对象写法适用于:要绑定多个样式,个数不确定,名字也不确定。 数组写法适用于:要绑定多个样式,个数确定,名字也确定,但不确定用不用 style样式 :style=\\\"{fontSize:xxx

    2023年04月14日
    浏览(48)
  • Vue-14、Vue绑定style样式

    1、对象写法 2、数组写法 3、总结

    2024年02月02日
    浏览(39)
  • Vue-13、Vue绑定css样式

    1、绑定css样式字符串写法,适用于:样式的类名不确定 2、绑定class样式–数组写法,适用于:要绑定的样式个数不确定、名字也不确定。 3、绑定class样式–对象写法,适用于:要绑定的样式个数确定、名字也确定,但要动态决定用不用。

    2024年01月21日
    浏览(44)
  • 前端2023最全面试题(javaScript、typeScript、vue2、vue3、html、css、uniapp、webpack、vite、react)

    答案:JavaScript中的闭包是一种函数,它有权访问其词法环境的变量和其它函数。这意味着,即使其包含它的函数已经执行完毕,其词法环境仍然存在,因此可以访问其作用域内的变量。 答案:回调函数是在某个特定事件之后执行的函数。在JavaScript中,通常使用回调函数来处

    2024年02月06日
    浏览(65)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包