vue3中自定义组件使用v-model

下面是一个简单的例子 来说说明一下 组件使用数据绑定

App.vue

<template>
  <div class="container">
    <globai-header :user="userData"></globai-header>
    <!-- <column-list :list="testData"></column-list> -->
    <form class="form-horizontal my-2">
      <div class="form-group my-2">
         <validate-input  v-model="emailValue"></validate-input>
         {{emailValue}}
      </div>
    </form>
  </div>
</template>

<script lang="ts">
import { defineComponent, reactive, ref } from "vue";
import "bootstrap/dist/css/bootstrap.min.css";
import ValidateInput, { RulesProp } from "./components/ValidateInput.vue";

export default defineComponent({
  name: "App",
  components: {
    ValidateInput,
  },
  setup() {
    const emailValue = ref('zhangsan')
    return {
    emailValue
    };
  },
});
</script>

**ValidateInput.vue**

```javascript
<template>
  <form class="form-horizontal my-2">
    <div class="form-group my-2">
      <label for="inputEmail" class="col-sm-2 control-label">Email</label>
      <div class="col-sm-10 my-2">
        <input
          type="email"
          class="form-control"
          :class="{ 'is-invalid': inputRef.error }"
          id="inputEmail"
          :value="inputRef.val"
          @blur="validateInput"
          placeholder="Email"
          @input="updateValue"
        />
        <span class="form-text my-2 invalid-feeback" v-if="inputRef.error">
          {{ inputRef.message }}
        </span>
      </div>
    </div>
  </form>
</template>
<script lang="ts">
import { defineComponent, PropType, reactive } from "vue";

export type RulesProp = RuleProp[];

export default defineComponent({
  name: "ValidateInput",
  props: {
    emailValue: String,
  },
  setup(props: any, context: any) {
  
   
    const updateValue=(e:KeyboardEvent)=>{
      const targetValue = (e.target as HTMLInputElement).value
      inputRef.val = targetValue
      //  发送一个事件 名成为update:modelValue
      context.emit('update:modelValue',targetValue)
    }
    return {
   updateValue
    };
  },
});
</script>```

即可完成简单的组件双向绑定

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嘴巴嘟嘟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值