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


    一、需求背景

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

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

    二、将class与style绑定

    我们可以这样声明一个div

    1. <div
    2. class="baseStyle"
    3. :class="{vip:vipFlag,svip:sVipFlag}"
    4. >
    5. <p>尊敬的{{welcomeInfo}},您好!</p>
    6. </div>
    1. // 初始化响应式变量
    2. const userType = ref(0)
    3. const vipFlag =ref(0)
    4. const sVipFlag = ref(0)
    5. const welcomeInfo = ref('普通用户')
    1. .baseStyle {
    2. font-family: "HarmonyOS Sans SC";
    3. }
    4. .vip {
    5. color: red;
    6. }
    7. .svip {
    8. font-style: italic;
    9. }

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

    1. onMounted(() => {
    2. // 假设这个方法是从后端调接口获取用户信息数据
    3. getuserInfo();
    4. // console.log("")
    5. setUsertype()
    6. })
    1. const getuserInfo = () => {
    2. userType.value = debugArray.value[0]
    3. vipFlag.value = debugArray.value[1]
    4. sVipFlag.value = debugArray.value[2]
    5. }
    6. const setUsertype = () => {
    7. welcomeInfo.value = (vipFlag.value ===1 || sVipFlag.value === 1)? "超级用户":"普通用户"
    8. }

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

    三、功能示例

    四、代码展示

    1. <template>
    2. <p>我是样式绑定</p>
    3. <div
    4. class="baseStyle"
    5. :class="{vip:vipFlag,svip:sVipFlag}"
    6. >
    7. <p>尊敬的{{welcomeInfo}},您好!</p>
    8. </div>
    9. </template>
    10. <script lang="ts" setup>
    11. import { computed, onMounted } from "vue";
    12. import { ref } from 'vue'
    13. // 初始化响应式变量
    14. const userType = ref(0)
    15. const vipFlag =ref(0)
    16. const sVipFlag = ref(0)
    17. const welcomeInfo = ref('普通用户')
    18. const debugArray = ref([0,1,1])
    19. // const welcomeInfo = () => computed(() => {
    20. // if (vipFlag.value ===1 || sVipFlag.value === 1){
    21. // return '超级用户'
    22. // }
    23. // return '普通用户'
    24. // // return (vipFlag.value ===1 || sVipFlag.value === 1)? "超级用户":"普通用户"
    25. // })
    26. const getuserInfo = () => {
    27. userType.value = debugArray.value[0]
    28. vipFlag.value = debugArray.value[1]
    29. sVipFlag.value = debugArray.value[2]
    30. }
    31. const setUsertype = () => {
    32. welcomeInfo.value = (vipFlag.value ===1 || sVipFlag.value === 1)? "超级用户":"普通用户"
    33. }
    34. onMounted(() => {
    35. // 假设这个方法是从后端调接口获取用户信息数据
    36. getuserInfo();
    37. // console.log("")
    38. setUsertype()
    39. })
    40. </script>
    41. <style scoped>
    42. .baseStyle {
    43. font-family: "HarmonyOS Sans SC";
    44. }
    45. .vip {
    46. color: red;
    47. }
    48. .svip {
    49. font-style: italic;
    50. }
    51. </style>

     

  • 相关阅读:
    sqlmap使用图解
    移远_M25_通话音量_DTMF测试
    halcon 感兴趣区域
    _gdb和进程概念
    学习Python要学习哪些课程?
    echarts插件使用初级的记录
    [MAUI]模仿Chrome下拉标签页的交互实现
    科研丨Web of Science检索技巧
    javascript实战开发:json数据求指定元素的和算法
    1079 Total Sales of Supply Chain
  • 原文地址:https://blog.csdn.net/m0_72678953/article/details/134025314