vue v-model在父子组件之间的运用

定义了一个table的子组件,声明props;父组件有数据源和数据列,通过props传入到子组件中。子组件的table有编辑功能,就意味着props的dataSource能被修改,接着dataSource又返回给父组件,进行提交或另作他用,那么如何实现呢?

这里就要用到v-model,在Vue 3.4+版本中,通过defineModel,很容易实现,我现在的vue版本为"vue": "3.2.37",所以得通过另一种方式实现,具体代码如下。

一、子组件:

const props = defineProps({
    columns: { type: Object, default: [] },
    dataSource: { type: Array, default: [] },
  });
const emit = defineEmits(['update:dataSource']);
const editData = ref([]);
  onMounted(() => {
    setTimeout(() => {
      if (props.columns && props.dataSource && props.dataSource.length > 0) { 
        editData.value = JSON.parse(JSON.stringify(props.dataSource)); //深拷贝
      }
    }, 500);
  });

通过defineProps、defineEmits配置要双向绑定的属性,所以update后面的属性名称必须和prop中的属性名称相同。下面实现update的代码:

 function handleInputChanged(value, rowIdx, colName) {
    for (let i in editData) {
      if (parseInt(i
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值