vue3报错 Unexpected mutation ofxxxprop.(eslintvue/nomutatingprops)

在这里插入图片描述

eslint校验这个错,其实是Vue单向数据流概念,因为识别到子组件修改props

这里踩到这个坑是这么操作的,我在父组件中给子组件传了个值,然后再子组件vmodle这个值,于是就给我报了这个错!

复现场景如下
组件

<enter-school ref="enterSchoolRef" :student-info="selectRows" /&gt;

组件

<template&gt;
    <el-form ref="formRef" class="enterForm" inline :model="form" :rules="rules" @submit.prevent&gt;
      <el-input
          v-model="studentInfo[0].name"
          clearable
          placeholder="请输入姓名"
        /&gt;
     </el-form&gt;
</template&gt;
<script>
    props: {
      studentInfo: {
        type: Array, //类型
        default: null //默认值
      },
    },
</script>

报错就在v-model="studentInfo[0].name"
应该在子组件直接双向绑定组件传递过来的值
解决方案

  1. 计算属性 依赖props进行计算/转换
<template>
 <el-input
      v-model="studentName"
      clearable
      placeholder="请输入姓名"
 />
</template>
<script>
    import { computed } from 'vue'
    props: {
      studentInfo: {
        type: Array, //类型
        default: null //默认值
      },
    }
    setup(props) {
      const studentName = computed(() =>
        props.studentInfo &amp;&amp;
        props.studentInfo.length > 0 ? props.studentInfo[0].name : null
      )
      return {
          studentName 
     }
    }
</scirpt>
  1. 定义中间变量 在子组件内的定义一个变量,并将接收props当作其初始值
<template>
 <el-input
      v-model="studentName"
      clearable
      placeholder="请输入姓名"
 />
</template>
<script>
    import { computed, defineComponent, reactive, toRefs } from 'vue'
    props: {
      studentInfo: {
        type: Array, //类型
        default: null //默认值
      },
     }
    export default defineComponent({
    setup(props) {
      const state = reactive({
        studentName : props.studentInfo[0].name
      })
      return {
          ...toRefs(state),
     }
    }
   })
</scirpt>

就是用的方案1,搞个计算属性解决

原文地址:https://blog.csdn.net/jieyucx/article/details/128289829

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_48322.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注