5 回答
data:image/s3,"s3://crabby-images/175c9/175c915e67c620b0011ddc60afac05875c344847" alt="?"
TA贡献1856条经验 获得超17个赞
数据中的项目(例如您的门票)被制作成可观察的对象。这是为了允许反应性(自动重新渲染 UI 和其他功能)。这是预期的,并且返回的对象的行为应该与数组一样。
如果您不想具有反应性 - 也许您从不更新客户端上的票证而只想显示它们 - 您可以在 response.data 上使用 Object.freeze() ;
data:image/s3,"s3://crabby-images/35527/35527520361f68aaa9d71809e7e566f0ecb701c6" alt="?"
TA贡献1921条经验 获得超9个赞
如果您想要反应性信息,请使用 toRaw
const foo = {} const reactiveFoo = reactive(foo) console.log(toRaw(reactiveFoo) === foo) // true
或者如果您不希望 ref 包装器围绕您的信息,请使用 unref
data:image/s3,"s3://crabby-images/61af9/61af9d0b7442f6ec9851c3d045276ad210a33a65" alt="?"
TA贡献1895条经验 获得超3个赞
您可以从返回的代理中检索数组响应对象,方法是将其转换为 JSON 字符串,然后再转换回数组,如下所示:
console.log(JSON.parse(JSON.stringify(this.tickets)));
data:image/s3,"s3://crabby-images/b57d7/b57d78e50183d10ac61a4d1c7b26fa442e717754" alt="?"
TA贡献1827条经验 获得超9个赞
你没有做错任何事。您刚刚发现了使用 vue 3 的一些复杂之处。
大多数情况下,您可以像使用原始数组对象一样使用代理数组对象。然而,文档确实指出:
使用代理确实引入了一个需要注意的新警告:代理对象在身份比较方面不等于原始对象(===)。
其他依赖于严格相等比较的操作也可能受到影响,例如 .includes() 或 .indexOf()。
文档中的建议尚未完全涵盖这些情况。我发现在检查 Object.values(array) 时我可以让 .includes() 工作。
data:image/s3,"s3://crabby-images/5822e/5822e300e0c47fe3513501d91a96b5a8dafc2925" alt="?"
TA贡献1836条经验 获得超4个赞
import { isProxy, toRaw } from 'vue';
let rawData = someData;
if (isProxy(someData)){
rawData = toRaw(someData)
}
添加回答
举报