vue3中的ref 和 reactive 定义数组

在vue3中,定义响应式数据一般有两种方式:ref 和 reactive

一般来说,我们使用 ref 来定义基本数据类型,使用 reactive 来定义复杂数据类型

但是也可以使用 ref 来定义数组

1、ref 定义数组

import { ref } from 'vue'

const arr = ref([])

两种情况:定义时就将数组初始化、定义时未初始化数组

初始化数组

import { ref,watch } from 'vue'

const arr = ref([1,2,3])

watch(arr.value, () => { //这个时候通过直接修改和利用数组的方法修改都可以监测到
  console.log('数组变化了')
})

const pushArray = () => {
  emptyArray.value.splice(0, 0, 19)
}

const changeArrayItem = () => {
  emptyArray.value[0] = 10
}

未初始化数组

import { ref,watch,onMounted } from 'vue'

const arr = ref([])

watch( //这个时候不能用.value且必须是深度监听,这种写法不仅可以监听数组本身的变化,也可以监听 数组元素的变化
  arr,
  () => {
    console.log('空数组变化了')
  },
  {
    deep: true
  }
)
const pushArray = () => {
  arr.value.splice(0, 0, { value: 12 })
}
const changeArrayItem = () => {
  arr.value[0] = { value: 32 }
}
onMounted(() => {
  arr.value = [{ value: 5 }, { value: 2 }, { value: 3 }, { value: 4 }]
})

2、reactive 定义数组 

import { reactive } from 'vue';

let arr = reactive([])

function change(){
   let newArr = [1,2,3]
   arr = newArr
}

但是这样定义的会出现问题,arr = newArr 这一步使得 arr 失去了响应式的效果

解决方法:可以使用 ref 定义、使用 push 方法、数组外层嵌套一个对象

import { reactive,ref } from 'vue';

let arr = reactive([])

function change(){
   let newArr = [1,2,3]
   arr = newArr
}


// 方法一:使用 ref
let arr = ref([])

function change(){
   let newArr = [1,2,3]
   arr.value = newArr
}


// 方法二:使用push 方法
let arr = reactive([])

function change(){
   let newArr = [1,2,3]
   arr.push(...newArr)
}

// 方法三:外层嵌套一个对象
let arr = reactive({list:[]})

function change(){
   let newArr = [1,2,3]
   arr.list = newArr
}

Vue 3中,您可以使用`ref``reactive`来声明变量对象。对于数组类型的变量对象,您可以使用JavaScript提供的`Array``Object`方法来修改它们的值。 对于`ref`声明的数组类型,您可以使用`value`属性来获取或修改它的值。例如: ```vue <template> <div> <h1>{{ myArray }}</h1> <button @click="updateArray">Update Array</button> </div> </template> <script> import { ref } from &#39;vue&#39;; export default { setup() { const myArray = ref([1, 2, 3]); const updateArray = () => { myArray.value.push(4); }; return { myArray, updateArray }; } }; </script> ``` 在这个例子中,我们使用`ref`声明了一个数组类型的变量`myArray`,并初始化它为`[1, 2, 3]`。我们还定义了一个`updateArray()`函数,用于将数字4添加到`myArray`中。在`updateArray()`函数中,我们使用`myArray.value`来访问`myArray`的值,并使用`push()`方法将数字4添加到数组末尾。 对于`reactive`声明的数组类型,您可以使用`Array`方法来修改它的值。例如: ```vue <template> <div> <h1>{{ myArray }}</h1> <button @click="updateArray">Update Array</button> </div> </template> <script> import { reactive } from &#39;vue&#39;; export default { setup() { const myArray = reactive({ numbers: [1, 2, 3] }); const updateArray = () => { myArray.numbers.push(4); }; return { myArray, updateArray }; } }; </script> ``` 在这个例子中,我们使用`reactive`声明了一个对象`myArray`,其中包括一个数组属性`numbers`,初始化为`[1, 2, 3]`。我们还定义了一个`updateArray()`函数,用于将数字4添加到`numbers`数组中。在`updateArray()`函数中,我们使用`myArray.numbers`来访问`numbers`数组,并使用`push()`方法将数字4添加到数组末尾。 总之,无论是`ref`还是`reactive`声明的数组类型,您都可以使用JavaScript提供的`Array`方法来修改它们的值。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值