vue 3.0 Reactive 数据更新页面没有刷新

导读:本篇文章讲解 vue 3.0 Reactive 数据更新页面没有刷新,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

vue 3.0 ref 和 Reactive 数据响应式,以及使用 Reactive 数据已更新但页面没有同步刷新异常

Vue 3.0 中我们使用 reactive() 定义的响应式数据的时候,当我们对象再次赋值,我们发现数据已经修改成功,但是页⾯并没有自动渲染成最新的数据;

这时我们可以改成 ref () 或者对 reactive() 绑定的数据类型下点功夫;

ref()

ref() 接受一个内部值并返回一个响应式且可变的 ref 对象。ref 对象仅有一个 .value property,指向该内部值


<template>
  <div>
    <button @click="changeMsg">更改数据</button>
    <div>{{ message }}</div>
  </div>
</template>

<script setup lang="ts">
import {ref} from 'vue'

/**
 *   ref() 基础用法
 */
 
let message = ref<string | number>("测试数据")

/**
 *   更改 ref 数据
 */
  
const changeMsg = () => {
   message.value = "更改测试数据"
}
</script>


reactive()

reactive() 主要时用来绑定一些复杂的数据类型,比如(对象、数组) ;它不可以绑定普通的数据类型,否则会报错;如果我们需要绑定普通的数据类型,建议使用上面的 ref()

<template>
  <div>
    <button @click="changeObj">更改数据</button>
    <div> {{obj.data}} </div>
    <div> {{obj.dataBoolean}} </div>
    <div> {{obj.dataArr}} </div>
  </div>
</template>

<script setup lang="ts">
import {reactive} from 'vue'

/**
 *   reactive() 基础用法
 */
 
const obj = reactive({
    data: '',
    dataBoolean: false,
    dataArr: <number[]>[],
})

/**
 *   更改 reactive() 数据
 */
 const changeObj = () => {
     obj .data = '测试数据'
     obj .dataBoolean = true
     obj .dataArr = [1, 2, 3, 4, 5, 6]
 }

</script>


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之家整理,本文链接:https://www.bmabk.com/index.php/post/6341.html

(0)
小半的头像小半

相关推荐

极客之家——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!