首页  >  问答  >  正文

v-model 无法与 Vue 3 中的 <component> 一起使用?

<p>为什么在下面的示例中 v-model 没有绑定到我的输入? <code><component></code> 有限制吗?</p>
<脚本设置>
从 'vue' 导入 { ref }

常量配置=参考({
  标题:[
    { 字段:'id',标签:'Id',组件:{ 类型:'输入' } }, 
    { field: '名称', label: '名称', 组件: { type: '输入' } },
    // 单选按钮和其他自定义组件的更多配置
  ],
  数据: [
    { id: 1, 名称: 'foo' },
    { id: 2, 名称: '酒吧' }
  ]
})
</脚本>

<模板>
  <表>
    <tr>
      
        <b>{{ header.label }}</b>
      </td>
    
    
      
        <组件:is="header.component.type" v-model="item[header.field]"; >>
      </td>
    
  </表>
  {{ 配置数据 }}
</模板></pre></p>
P粉806834059P粉806834059388 天前399

全部回复(1)我来回复

  • P粉081360775

    P粉0813607752023-08-30 10:30:14

    Vue v-model 对于原生元素来说效果很好。

    但它显然无法与 一起使用

    您的代码生成

    <input modelvalue="foo">

    非常快速的解决方法是直接实现的绑定。

    :value="item[header.field]" @input="item[header.field] = $event.target.value"

    但是您将需要相应地更新组件,以使用 value 而不是 modelValue

    更新

    使用 v-model:value 的解决方法仅以一种方式起作用,与 :value 相同。

    <component :is="header.component.type" v-model:value="item[header.field]" />

    const { createApp, ref } = Vue
    
    const config = ref({
      headers: [
        { field: 'id', label: 'Id', component: { type: 'input' } }, 
        { field: 'name', label: 'Name', component: { type: 'input' }  },
        // more configs for radio buttons and other custom components
      ],
      data: [
        { id: 1, name: 'foo' },
        { id: 2, name: 'bar' }
      ]
    })
    
    const App = {
      setup() {
        return { config, test: 1 }  
      }
    }
    
    const app = createApp(App)
    app.mount('#app')
    #app { line-height: 1.75; }
    [v-cloak] { display: none; }
    <div id="app">
    <table>
        <tr>
          <td v-for="header in config.headers">
            <b>{{ header.label }}</b>
          </td>
        </tr>
        <tr v-for="item in config.data">
          <td v-for="header in config.headers">
            <component :is="header.component.type" :value="item[header.field]" @input="item[header.field] = $event.target.value" />
          </td>
        </tr>
      </table>
      {{ config.data }}
      <hr/>
      v-model test: <input v-model="test" />
    </div>
    <script src="https://unpkg.com/vue@3/dist/vue.global.prod.js"></script>

    回复
    0
  • 取消回复