IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> vue3 reactive的坑 -> 正文阅读

[游戏开发]vue3 reactive的坑

最近使用vue3的过程中发现reactive有一些问题

  1. 清空reactive定义的数组时必须将length设为0,直接赋值一个空数组是没有作用的,同理对象直接赋值一个空对象也没有作用,只能遍历对象一项一项删,这里说的没有作用是不能响应式的更新页面,如果打印一下是能看到确实被删除了,但是页面没有变化

    清空数组

    // 错误示例
    <template>
      <div>{{ arr }}</div>
      <button @click="click">点击</button>
    </template>
    
    <script setup>
    import { reactive } from 'vue'
    let arr = reactive([1, 2, 3])
    const click = () => {
      arr = []
      console.log(arr) // 这里打印的结果是正常的空数组
    }
    </script>
    // 正确示例
    <template>
      <div>{{ arr }}</div>
      <button @click="click">点击</button>
    </template>
    
    <script setup>
    import { reactive } from 'vue'
    let arr = reactive([1, 2, 3])
    const click = () => {
      arr.length = 0 // 这里和vue2是正好相反,vue2直接将数组length设为0是无效的
      console.log(arr)
    }
    </script>

    清空对象

    // 错误示例
    <template>
      <div>{{ obj }}</div>
      <button @click="click">点击</button>
    </template>
    
    <script setup>
    import { reactive } from 'vue'
    let obj = reactive({a: 111, b: 222})
    const click = () => {
      obj = {}
      console.log(obj) // 这里打印的结果是正常的空对象
    }
    </script>
    // 错误示例
    <template>
      <div>
        <div>{{ obj }}</div>
        <button @click="click">点击</button>
      </div>
    </template>
    
    <script setup>
    import { reactive } from 'vue'
    let arr = reactive({a: xxx, b: xxx })
    const click = () => {
      for (let i in obj) {
        delete obj[i]
      }
      console.log(obj) // 这里打印的结果是正常的空数组
    }
    </script>
  2. 同样的道理直接赋值也不行,数组只能用数组的某些方法,或者直接修改索引,修改索引跟vue2又是相反,vue2只修改索引项没有作用,对象直接使用点语法即可,直接赋一个对象没有作用
  3. 这些问题其实只要使用ref就可以解决,但是人官方推荐使用reactive。。。。
  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-04-04 12:42:53  更:2022-04-04 12:44:38 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 18:36:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码