0

0

如何在 Vue 3 中解除变量的响应式绑定

心靈之曲

心靈之曲

发布时间:2026-01-01 14:31:49

|

862人浏览过

|

来源于php中文网

原创

如何在 Vue 3 中解除变量的响应式绑定

vue 3 中,直接赋值无法脱离响应式系统;若需对 `reactive` 对象做无副作用的修改(如删除字段而不影响原对象),应先用 `toraw()` 获取原始对象,再通过展开运算符创建独立副本。

在 Nuxt 3 或纯 Vue 3 项目中,当你使用 const formData = reactive({ name: 'Alice', email: 'a@example.com', token: 'xxx' }) 定义表单数据时,该对象及其所有嵌套属性均被 Proxy 包裹,具备响应式能力。此时若执行 submitData = formData,实际只是复制了响应式代理的引用——submitData 和 formData 指向同一响应式对象,因此 delete submitData.token 会同步反映到 formData 上,违背预期。

✅ 正确做法是:剥离响应式代理,再构造新响应式对象。Vue 提供了 toRaw() 工具函数,用于安全获取被 reactive()、ref() 等包裹的原始对象(非 Proxy 版本)。配合对象展开语法,即可生成一份与原对象结构一致、但完全独立的副本:

import { reactive, toRaw } from 'vue'

const formData = reactive({
  name: 'Alice',
  email: 'a@example.com',
  token: 'abc123',
  createdAt: new Date()
})

// 创建独立的、可自由修改的 reactive 副本
const submitData = reactive({ ...toRaw(formData) })

// ✅ 安全删除,不影响 formData
delete submitData.token
delete submitData.createdAt

console.log(formData.token)       // 'abc123' —— 未被删除
console.log(submitData.token)     // undefined —— 已删除

⚠️ 注意事项:

Pi智能演示文档
Pi智能演示文档

领先的AI PPT生成工具

下载
  • toRaw() 仅对由 Vue 创建的响应式对象有效;对普通对象调用无副作用,但无必要;
  • 若 formData 含深层嵌套对象或数组,{ ...toRaw(formData) } 仅执行浅拷贝,嵌套属性仍可能共享引用(如 formData.profile = reactive({ age: 30 }))。此时建议结合 structuredClone()(现代浏览器支持)或 lodash.cloneDeep() 进行深拷贝后再 reactive();
  • 不推荐在模板中频繁调用 toRaw(),它属于底层工具,应仅用于逻辑隔离场景(如提交前清洗数据);
  • 替代方案:若无需保留响应式,也可直接使用 const submitData = { ...toRaw(formData) }(非 reactive),适用于一次性提交场景。

总结:toRaw() 是 Vue 3 提供的关键“脱敏”工具,配合解构赋值可高效实现响应式对象的隔离拷贝。在表单提交、API 请求载荷构建等需要临时修改数据又不污染源状态的场景中,这是简洁、可靠且符合 Vue 哲学的标准实践。

立即学习前端免费学习笔记(深入)”;

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1435

2023.10.24

Go语言中的运算符有哪些
Go语言中的运算符有哪些

Go语言中的运算符有:1、加法运算符;2、减法运算符;3、乘法运算符;4、除法运算符;5、取余运算符;6、比较运算符;7、位运算符;8、按位与运算符;9、按位或运算符;10、按位异或运算符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2024.02.23

php三元运算符用法
php三元运算符用法

本专题整合了php三元运算符相关教程,阅读专题下面的文章了解更多详细内容。

85

2025.10.17

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6045

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

782

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1047

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

1093

2024.03.01

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

519

2023.09.20

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

62

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 5.8万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号