
Vue 3 中 ref 响应式失效的解决方法:表格选择框更新案例
在 Vue 3 项目开发中,有时会遇到 ref 定义的变量在数据更新后,页面无法响应的情况,例如表格选择框无法正确更新。
问题根源分析
这个问题通常是因为 ref 仅能包装基本数据类型(如数字、字符串),而当我们将对象或数组赋值给 ref 时,ref 就无法追踪其内部属性的变化,从而导致响应式失效。
立即学习“前端免费学习笔记(深入)”;
解决方案:使用 reactive API
为了解决这个问题,我们需要使用 Vue 3 的 reactive API 来定义数据。reactive 可以处理复杂数据类型,如对象和数组,并使其具有响应式能力。
import { reactive } from 'vue'
const rowSelections = reactive({})
通过 reactive 创建的 rowSelections 对象,其属性变化将会自动触发视图更新。
ref 和 reactive 的区别
ref 和 reactive 的主要区别在于它们处理的数据类型和使用方法:
-
ref用于包装基本数据类型,在模板中访问其值需要使用.value属性。 -
reactive用于包装复杂数据类型(对象、数组),可以直接访问其属性。
通过将 ref 替换为 reactive,可以有效解决 Vue 3 中 ref 响应式失效的问题,确保表格选择框等组件能够正确响应数据变化。










