vue.js:634 [Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever t

2023-05-16

   其实是前两天了解了v-mdel的原理

<!-- v-model原理-->
<div id="demo">
 <input :value="value" @input="price=$event.target.value">
</div>

<script>
 new Vue({ 
   el:'#demo',
   data:{
      price:1000 
   }
})
</script>

然后想使用v-model原理 应用到父子组件的通信中(父传子,子传父)

先展示一下代码:

<body>
    <!-- 本组件 -->
    <div id="demo">
        <!-- 父传子 把变化的变量传递 -->
        <currency-input :value="price" @input="(val) => (price = val)">
            </currentcy-input>
    </div>
    <script>
        // 全局组件
        Vue.component('currency-input', {
            template: `
         <span>
          <input
           :value="value"
           @input="$emit('input', $event.target.value)"
          >
         </span>
        `,
            props: ['value'],
        })
        //vue实例
        var demo = new Vue({
            el: '#demo',
            data: {
                price: 1000
            }
        })
    </script>
</body>

在浏览器中的展示:

在父组件中修改应用的子组件的input中的值(子传父)和data中的值(父传子)都能实现双向绑定

 

                          在子组件中修改input中的值能实现(子传父)

                                 但是修改 props中的值就会报如下错:

 原因:

 父组件通过props传值给子组件,子组件改变props的属性值导致;,先看一眼官方文档:

父子组件中的数据流是单向的,父子之间形成了一个单向绑定:父级data的更新会向下流动到子组件中,但是反过来子修改props则不行。(父组件更新,子组件中的props值也会更新,但子组件不能修改props值再传给父组件);

解决方案:

将传递给子组件的数据改为对象形式,在子组件中用对象属性去渲染:

    <!-- 本组件 -->
    <div id="demo">
        <!-- 父传子 把变化的变量传递 -->
        <currency-input :value="price" @input="(val) => (price = val)">
            </currentcy-input>
    </div>
    <script>
        // 全局组件
        Vue.component('currency-input', {
            template: `
         <span>
          <input
           :value="value.num"
           @input="$emit('input', $event.target.value)"
          >
         </span>
        `,
            props: ['value'],
        })
        //vue实例
        var demo = new Vue({
            el: '#demo',
            data: {
                price: {
                    num: 1000
                }
            }
        })
    </script>


将传过去的数据改为对象,再用对象属性去渲染,确实不会报警告了!!!

 这样虽然解决但是根据官方文档的翻译,我们可以理解为props中的属性最好避免改动,已经提醒你了,出错了算你自己的。所以方案二是最优方案

解决方案二:

       我们可以在data中重新定义相应的属性来接收props中的属性。

  <!-- 本组件 -->
    <div id="demo">
        <!-- 父传子 把变化的变量传递 -->
        <currency-input :value="price" @input="(val) => (price = val)">
            </currentcy-input>
    </div>
    <script>
        // 全局组件
        Vue.component('currency-input', {
            template: `
         <span>
          <input
           :value="price"
           @input="$emit('input', $event.target.value)"
          >
         </span>
        `,
            props: ['value'],
            data: function () {
                return {
                    price: this.value
                }
            }
        })
        //vue实例
        var demo = new Vue({
            el: '#demo',
            data: {
                price: 1000
            }
        })
    </script>

 

   

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

vue.js:634 [Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever t 的相关文章

  • 自动控制算法的学习笔记

    1 PID调试步骤 没有一种控制算法比PID调节规律更有效 更方便的了 现在一些时髦点的调节器基本源自PID 甚至可以这样说 xff1a PID调节器是其它控制调节算法的基础 为什么PID应用如此广泛 又长久不衰 xff1f 因为PID解决
  • stm32 应用实例—— USART 串口通讯

    stm32 应用实例 USART 串口通讯 1 基于寄存器 固件库编程的差异性2 完成STM32的USART窗口通讯程序4 重温C语言程序里全局变量 局部变量 堆 栈等概念 xff0c 并验证3 归纳出stm32的堆 栈 全局变量的分配地址
  • windows BDA driver (abstract)

    AVStream is a Microsoft provided multimedia class driver that supports video only streaming and integrated audio video s

随机推荐

  • 详细解读Python豆瓣电影Top250网页爬取(主要对re的运用&excel保存数据)//包括对库的简介

    python里面有很多操作都类似于c语言 xff0c 这里在爬取时主要需要注意用到的是for循环语句和各种库 个人认为python中主要还是对库的运用比较占大比例 xff08 这里的软件版本是PyCharm 2020 3 2 x64 xff
  • Unity3D 委托和事件的优点(一)

    上周接触到了委托 这周终于在自己的项目中用到了 现在准备用委托和事件的方案 替换掉之前的一些使用不足的解决方案 在此感谢前辈们的优秀文章 我是根据在网上阅读的文章 通过自己的见解 并在自己的项目中进行实践 得出了一些结论与大家分享 我认为这
  • 我的保研经历——中国科学院计算技术研究所

    忙碌了大半年的保研事情已经尘埃落定了 xff0c 心理也踏实下来了 xff0c 总想着把自己的这段保研经历记录下来 xff0c 希望能对小伙伴们有所帮助 能来到ZZ并且读软件工程这个专业并且阴差阳错的进了卓越班也算是老天注定吧 xff08
  • 无限循环:while True+if...break(打破循环) 用法

    span class token keyword while span True span class token punctuation span p span class token operator 61 span span clas
  • freertos的核心---线程与调度

    一 划重点 划重点 划重点 线程就是freertos运行管理的最小单位 一个线程有自己的生命周期 可以是一段时间也可以是forever 具体看开发人员对于线程的规划 几个线程 每个线程处理什么事情 先来看看线程长啥样 xff1f xff08
  • freertos通信---信号量与队列

    嘿嘿 又见面了 到这里 任务的调度和切换 你已经有了深刻的理解 接下来 自然而然就是任务间的通讯咯 把相关的任务串联起来 就形成了程序的基本架构 一 队列 为什么要先讲解队列了 因为信号量就是利用队列来实现的 走 一起瞅瞅 1 1队列的创建
  • freertos通讯---信号量与队列

    哈喽 又见面了 一 信号量 1 1创建二进制信号量 define xSemaphoreCreateBinary xQueueGenericCreate UBaseType t 1 semSEMAPHORE QUEUE ITEM LENGTH
  • 关于python调用C++

    关于python调用C C 43 43 查了很多相关资料 xff0c 可以通过ctypes模块 SWIG等一些方法 简单的类似单个头文件单个cpp文件都可以实现 xff0c 但是大恒给的C 43 43 包含驱动程序 xff0c 需要在属性里
  • freertos通讯-通知

    通知是什么 xff1f 其实我们之前就见过 它就在任务结构体中 再来回顾下 if configUSE TASK NOTIFICATIONS 61 61 1 volatile uint32 t ulNotifiedValue volatile
  • freertos软件定时器

    哈喽 这篇文章是freertos解析的最后一篇文章 我们将会讲解一个利用任务延时实现的软件定时器 1 创建 timer结构体和创建一目了然 看看初始化函数 是不是有点熟悉 timer的管理有点类似任务的管理 如果是第一次创建则初始化time
  • 蓝牙5.1的ble那些事儿

    既然要说5 1的那些事儿 那么必须的聊聊蓝牙4 0 本文就不在此长篇大论班门弄斧了 要了解4 0的同学请出门左拐直接去参考蜗窝科技大佬的文章 本人觉得对于想入门全面了解4 0的同学 此文章是不二选择的经典 在此只有膜拜的份了 不是广告哈哈
  • 蓝牙5.1的ble那些事儿

    到这里 对于非连接状态应该有一些新的认识了 接下来 顺其自然当然就是连接了 你谈对象 忙活半天 当然是想干点什么事情了 当然也有老司机翻车 连接上后 一端要主动向另一端发起问候 否则长时间不联系 那么就断开好了 主动问候的一端我们称之为ma
  • Http auth认证的两种方式Basic方式和 Digest认证

    Http Basic Auth 方式 当访问一个Http Basic Auth 网站的时候需要提供用户名 xff0c 密码 xff0c 否则会返回401 without authoration Http Basic Authenticati
  • while无限循环

    无限循环写法while 1 循环体内部可以用break语句跳出循环 while 1
  • 不同操作系统下的程序入口点分析

    转自 http hi baidu com liu bin0101 blog item 03e3a9ec4e0fd5d72e2e21b9 html 程序入口与编译器没有什么关系 关键是链接链接器 UNIX的用的ld和WINDOWS下用的LIN
  • rv-player 不靠谱之rvio

    最近忽然发现为动画组写过的一个maya内置工具不能用了 xff0c 工具的作用是使用rvio hw exe转换playblast出的tif序列图 xff0c 生成带watermark的mov文件 之前在Maya2013上一直用的好好地 xf
  • 树莓派 Raspberry Pi SD卡系统备份与还原

    近半年时间用来监控陆龟的树莓派 Raspberry Pi 还算稳定 xff0c 可到了冬天龟箱里的加热灯长时间加热导致树莓派温度很高 xff0c 时不时的自动重启 如果每次都能正常起来也就罢了 xff0c 可偶尔会挂不上SD卡的文件系统直接
  • 2022-12-18 CMakelists指定CMAKE_BUILD_TYPE为Debug或者Release

    今天编译代码的时候遇到古怪的事情 xff0c 在Cmakelists txt中指定了编译版本 xff0c build的时候输出一句 xff1a cpptools The build configurations generated do n
  • 5.FreeRTOS任务切换的简易分析

    FreeRTOS任务切换的简易分析 架构 xff1a Cortex M3版本 xff1a FreeRTOS V9 0 0前言 xff1a 之前分析了创建任务 启动调度器 xff0c 在做完这些工作后 xff0c 就是该完成所有RTOS的最核
  • vue.js:634 [Vue warn]: Avoid mutating a prop directly since the value will be overwritten whenever t

    其实是前两天了解了v mdel的原理 lt v model原理 gt lt div id 61 34 demo 34 gt lt input value 61 34 value 34 64 input 61 34 price 61 even