Vue3 v-model 组件传值

本文展示了如何在Vue中创建一个数量选择组件`CheckNumber`,该组件包含加减按钮,用于数量的增减,并通过`v-model`双向绑定实现值的传递。组件内部使用`ref`和`watch`来响应模型值的变化,同时提供`add`和`ins`方法更新数值并触发父组件的值更新事件。
摘要由CSDN通过智能技术生成
<CheckNumber :max="5" :min="1" v-model="num"/>

给其他组件传值

<template>
  <div class="xtx-numbox">
    <div class="label">数量</div>
    <div class="numbox">
      <a href="javascript:;" @click="ins">-</a>
      <input type="text" readonly :value="num">
      <a href="javascript:;" @click="add">+</a>
    </div>
  </div>
</template>
<script>
import { ref, watch } from 'vue'
export default {
  name: 'CheckNumber',
  props: {
    max: {
      type: Number

    },
    min: {
      type: Number,
      default: 1
    },

    // 接收v-modle
    modelValue: {
      type: Number
    }
  },
  setup (props, { emit }) {
    // 定义num接收传过来的值
    const num = ref(props.modelValue)

    // 监听num的变化
    watch(() => {
      return props.modelValue
    }, () => {
      num.value = props.modelValue
    })

    function add () {
      if (num.value === props.max) {
        return
      }
      num.value++

      // 向父组件发送事件
      emit('update:modelValue', num.value)
    }
    function ins () {
      if (num.value === props.min) {
        return
      }
      num.value--
      emit('update:modelValue', num.value)
    }

    return {
      num,
      add,
      ins
    }
  }
}

接收的组件

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值