本篇内容介绍了“Vue警告Write operation failed:computed value is readonly如何解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
浏览器控制台警告:Write operation failed: computed value is readonly
Vue 3.2.41
Chrome x64 v103.0.5060.66
利用Vue的响应式修改某个值时出现该警告。
<template> {{ msg }} <br> <button @click="add">+</button> </template>
<script setup lang="ts"> import { computed, ref} from 'vue' const x = ref('-') // 计算属性 const msg:any = computed(()=>{ return x.value + '-' }) // 修改 计算属性的值 的方法 const add = () => { msg.value = msg.value + '???' } </script>
修改的值是计算属性,而计算属性是只读的。所以无法修改。
为计算属性配置修改方法,如下:
<script setup lang="ts"> import { computed, ref} from 'vue' const msg = ref('-') // 计算属性 const computedMsg: any = computed({ get() { // 这里返回的值是获取计算属性的值 return msg.value + '-' }, set(newValue) { // 参数newValue是被修改后的值 // 这里是修改的具体逻辑 /* 注意这里不要使用下面的方法修改计算属性的值来达到修改目的 而应该直接修改源响应数据xxx的值 */ msg.value = newValue // computedMsg.value = newValue } }) // 修改 计算属性的值 的方法 const add = () => { computedMsg.value = computedMsg.value + '???' } </script>
“Vue警告Write operation failed:computed value is readonly如何解决”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。