vue 使用v-model绑定自定义子组件

v-model大部分解释是语法糖,其实就是在父组件中定义一个变量,通过v-model绑定变量传入子组件中,并在子组件改变这个值时,父组件能拿到最新到数据


下面具体说说如何通过v-model绑定自定义组件,算了,也没什么说的,也不知道咋说,直接看代码吧!

首先我们有一个父组件

<template>
    <div>
        <el-button @click="dialogVisible_new = true">新增参数</el-button>
        <el-dialog
                title="新增参数"
                :visible.sync="dialogVisible_new"
                size="tiny"
        >
            <newParamModel ref="new" v-model="newParamData"/>
            <span slot="footer" class="dialog-footer">
                <el-button @click="dialogVisible_new = false">取 消</el-button>
                <el-button type="primary" @click="handleNewParam">新 增</el-button>
              </span>
        </el-dialog>
    </div>
</template>
<script>
    import newParamModel from "./newParamModel"
  export default {
    data() {
      return {
        newParamData:{
          name:"",
          required:false,
          explain:""
        },
        dialogVisible_new:false,
      }
    },
    components:{
      newParamModel
    },
    methods:{
      handleNewParam(){
        console.log(this.newParamData)
      }
    }
  }
</script>

功能是点击按钮弹出对话框,对话框是一个表单子组件,这里绑定了变量newParamData,在子组件中用value来取model值,

下面是子组件newParamModel的代码

<template>
    <div>
        <el-form :model="value" label-width="120px" ref="newParamForm" >
            <el-form-item label="参数名称:" prop="name">
                <el-input v-model="value.name" placeholder="请输入参数名称"></el-input>
            </el-form-item>
            <el-form-item label="是否必填:" prop="required">
                <el-switch
                        v-model="value.required"
                        on-text="是"
                        off-text="否">
                </el-switch>
            </el-form-item>
            <el-form-item label="参数说明:" prop="explain">
                <el-input v-model="value.explain"
                          placeholder="请输入参数说明"
                          type="textarea"
                          :rows="3"></el-input>
            </el-form-item>
        </el-form>
    </div>
</template>
<script>
  export default {
    props:["value"]
  }
</script>

就这样,父组件可以直接取到子组件中表单值到变化

也可以使用input事件向父组件传值,

this.$emit('input',data)

有的时候可能value会报错,vue不允许数据双向绑定,这时候在子组件中定义一个新的变量代替value,最后通过input事件向父组件传值就可以来

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue中,使用v-model绑定三目运算符会报错"'v-model' directives require the attribute value which is valid as LHS",这是因为v-model绑定的属性必须是合法的左侧值。这意味着v-model绑定属性必须是一个能够被修改的变量,而不是一个表达式或计算属性。 要解决这个问题,你可以改为使用v-bind来绑定class,并使用三目运算符来动态决定class的值。这样就可以避免v-model绑定属性的报错。 另外,需要注意的是,v-model是v-bind的缩写形式,并且v-model在单个元素和一组元素中的行为是不同的。在使用v-model时,需要根据具体情况来选择合适的使用方式。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [vue中v-model绑定三目运算符报错解决](https://blog.csdn.net/qq_43532275/article/details/125868403)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [在vue中v-bind使用三目运算符绑定class的实例](https://download.csdn.net/download/weixin_38703277/12951495)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值