复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <style>
    .red{
      background-color: red;
    }

    .yellow{
      background-color: yellow;
    }
    .aa{

    }
    .bb{

    }
    .cc{

    }
    .dd{

    }

  </style>
  <script src="lib/vue.js"></script>
</head>
<body>
  <div id="box">
     <div :class="classobj">动态切换class-1-对象</div>
     <div :class="classarr">动态切换class-2-数组</div>

     <div :style="styleobj">动态切换style-1-对象</div>
     <div :style="stylearr">动态切换style-2-数组</div>
  </div>

  <script>
      var vm = new Vue({
        el:"#box",
        data:{
          classobj:{
            aa:true,
            bb:true,
            cc:false
          },
          classarr:["aa","bb"],
          styleobj:{
            backgroundColor:'red'
          },
          stylearr:[{backgroundColor:"yellow"}]
        }
      })

      // vue2 解决方案, Vue.set(对象,属性,true) Vue.set(vm.classobj,"dd",true)

      // vue3 支持动态增加属性的拦截
  </script>
</body>
</html>
复制代码

总结:

用style时,要用驼峰方式写。

vue2中对象可以用Vue.set(对象,属性,true)进行动态绑定,如果是数组的话,不需要Vue.set,因为已经重写了。

vue3 支持动态增加属性的拦截

posted on   weakup  阅读(136)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
历史上的今天:
2019-03-23 springBoot上传文件大小设置
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示