搜索

首页  >  问答  >  正文

Vue 3:如何使用组合 API 正确更新组件 props 值?

我喜欢这个组件:

<template>
  <div>
    <p>Current coords: <strong>{{ coords }}</strong></p>
    <button type="button" @click="updateCoords">
  </div>
</template>
<script>
export default {
  props: {
    coords: {
      type: Array,
      required: true
    }
  },
  setup(props) {
    const updateCoords = () => {
      props.coords = [38.561785, -121.449756]
      // props.coords.value = [38.561785, -121.449756]
    }
    return { updateCoords }
  },
}
</script>

我尝试使用 updateCoords 方法更新 prop coords 值,但收到错误消息:

未捕获类型错误:无法设置未定义的属性(设置 '坐标')

在我的情况下如何正确更新 props 值?

P粉951914381P粉951914381291 天前535

全部回复(1)我来回复

  • P粉306523969

    P粉3065239692024-03-26 17:28:10

    道具是只读的:
    https://v3.vuejs.org/guide/component -props.html#one-way-data-flow

    如果你想要有两种方式绑定 props,你需要实现 v-model 模式:
    https://v3-migration.vuejs.org /break-changes/v-model.html#_3-x-syntax

    
    sssccc

    回复
    0
  • 取消回复