vueDay03——可灵活变动的class样式

一、需求背景

有时候我们需要对不同身份的用户在同一个组件上展示不同的样式(界面这里暂且不谈),我们就需要控制该组件在不同的数据下呈现不同的样式

这时候我们就可以使用:class属性来动态调整样式

二、将class与style绑定

我们可以这样声明一个div

复制代码
<div
    class="baseStyle" 
    :class="{vip:vipFlag,svip:sVipFlag}"
    > 
        <p>尊敬的{{welcomeInfo}},您好!</p>
 </div>

// 初始化响应式变量
const userType = ref(0)
const vipFlag =ref(0)
const sVipFlag = ref(0)
const welcomeInfo = ref('普通用户')

.baseStyle {
    font-family: "HarmonyOS Sans SC";
}
.vip {
    color: red;
}
.svip {
    font-style: italic;
}

然后通过后端接口,在页面渲染完毕的时候获取数据,将数据渲染上去

复制代码
onMounted(() => {
    // 假设这个方法是从后端调接口获取用户信息数据
    getuserInfo();
    // console.log("")
    setUsertype()
})

const getuserInfo = () => {
    userType.value = debugArray.value[0]
    vipFlag.value  = debugArray.value[1]
    sVipFlag.value = debugArray.value[2]
}

const setUsertype = () => {
     welcomeInfo.value = (vipFlag.value ===1 || sVipFlag.value === 1)? "超级用户":"普通用户"
}

通过判断后端传来的不同数据(前端使用一个数组进行模拟)来渲染不同的样式

三、功能示例

四、代码展示

复制代码
<template>
    <p>我是样式绑定</p>
    <div
    class="baseStyle" 
    :class="{vip:vipFlag,svip:sVipFlag}"
    > 
        <p>尊敬的{{welcomeInfo}},您好!</p>
    </div>
</template>

<script lang="ts" setup>
import { computed, onMounted } from "vue";
import { ref } from 'vue'
// 初始化响应式变量
const userType = ref(0)
const vipFlag =ref(0)
const sVipFlag = ref(0)
const welcomeInfo = ref('普通用户')

const debugArray = ref([0,1,1])
// const welcomeInfo = () => computed(() => {
//     if (vipFlag.value ===1 || sVipFlag.value === 1){
//         return '超级用户'
//     }
//     return '普通用户'
//     // return (vipFlag.value ===1 || sVipFlag.value === 1)? "超级用户":"普通用户"
// })

const getuserInfo = () => {
    userType.value = debugArray.value[0]
    vipFlag.value  = debugArray.value[1]
    sVipFlag.value = debugArray.value[2]
}

const setUsertype = () => {
     welcomeInfo.value = (vipFlag.value ===1 || sVipFlag.value === 1)? "超级用户":"普通用户"
}
onMounted(() => {
    // 假设这个方法是从后端调接口获取用户信息数据
    getuserInfo();
    // console.log("")
    setUsertype()
})
</script>

<style scoped>
.baseStyle {
    font-family: "HarmonyOS Sans SC";
}
.vip {
    color: red;
}
.svip {
    font-style: italic;
}
</style>
相关推荐
iDao技术魔方4 分钟前
Bun v1.3.12 深度解析:新特性、性能优化与实战指南
开发语言·javascript·visual studio code
小兵阿飞7 分钟前
Vite 技术介绍:实现原理、应用与优化
前端·vite
码喽7号17 分钟前
vue学习六:状态管理VueX
javascript·vue.js·学习
jiayong2318 分钟前
第 13 课:分页、页码状态和 URL 同步
开发语言·前端·javascript·vue.js·学习
阿正的梦工坊28 分钟前
JavaScript 闭包 × C++ 类比:彻底搞懂闭包
开发语言·javascript·c++
smilejingwei44 分钟前
用 AI 编程生成 ECharts 图表并嵌入报表的实践
前端·人工智能·echarts·bi·报表工具·商业智能
Linux运维技术栈1 小时前
Cloudflare Argo Smart Routing全球加速:优化跨境回源链路,提升跨区域访问体验
大数据·前端·数据库
恋猫de小郭2 小时前
Android CLI ,谷歌为 Android 开发者专研的 AI Agent,提速三倍
android·前端·flutter
Hello--_--World2 小时前
Js 隐式类型转换、JavaScript `==` vs `===` 深度对比表
开发语言·javascript·ecmascript
freewlt2 小时前
从 0 搭建现代前端组件库:2026年完整实战指南
前端