将一个组件的propName属性与父组件中的variable变量进行双向绑定的vue3(组件传值)

封装组件看这个,然后理解父子组件传值

应用场景:

1.使用v - model语法实现双向绑定(传值两边都不用定义方法接数据)

1.子组件
1. @update:modelValue事件是MultiSelect组件对象自带的事件
2.:options="countries"

options是MultiSelect对象自带的可以接受自定义值的属性

countries是我们封装的接受外部自定义值的属性。。引用关系有点复杂

3.代码
复制代码
<template>
  <div class="card flex justify-center">
    <MultiSelect v-model="selectedCountries" :options="countries" optionLabel="name" @update:modelValue="$emit('update:selectedCountries',selectedCountries)" filter placeholder="Select Countries" display="chip" class="w-full md:w-80">

      <template #option="slotProps">
        <div class="flex items-center">
          <div>{{ slotProps.option.name }}</div>
        </div>
      </template>
      <template #dropdownicon>
        <i class="pi pi-map" />
      </template>
      <template #filtericon>
        <i class="pi pi-map-marker" />
      </template>
      <template #header>
        <div class="font-medium px-3 py-2">Available Countries</div>
      </template>
      <template #footer>
        <div class="p-3 flex justify-between">
          <Button label="Add New" severity="secondary" text size="small" icon="pi pi-plus" />
          <Button label="Remove All" severity="danger" text size="small" icon="pi pi-times" />
        </div>
      </template>
    </MultiSelect>
  </div>
</template>

<script setup>
import {onMounted, ref} from "vue";
// import { MultiSelect } from 'primevue/multiselect';
// import { Button } from 'primevue/button';

const props = defineProps({
  // 可以添加自定义的props,例如是否禁用组件等
  disabled: {
    type: Boolean,
    default: false
  },
   countries:{
    type: Array,

     required: true
   },
    selectedCountries:{
      type: Array,

    },
  visible:{
    type: Boolean,
    default: false

  }

});

const selectedCountries = ref([])
// 如果需要根据父组件传入的值改变内部数据结构,可以在这里处理
// 例如:
// if (props.someValue) {
//     // 对countries或者selectedCountries进行操作
// }

// 可以定义内部的方法,如果需要暴露给父组件,可以使用emits
const emit = defineEmits(['update:selectedCountries']);
const emitModelValueChange = () => {
  emit('update:modelValue', selectedCountries);
};
</script>
2.父组件
1.selectedCountries这个变量我们没有在父组件里定义,这个是跟在事件之后的参数,也是我们要传的值
2.selectedUsers这个变量就是父组件所属的了

3.界面效果

2.手动实现双向绑定(不使用v - model语法的传统方式)(传值两边都需要定义方法接数据)

1.子组件
复制代码
<template>
  <div class="card flex justify-center">
<MultiSelect v-model="selectedCountries" :options="countries" optionLabel="name" @update:modelValue="emitModelValueChange" filter placeholder="Select Countries" display="chip" class="w-full md:w-80">
      <template #option="slotProps">
        <div class="flex items-center">
          <div>{{ slotProps.option.name }}</div>
        </div>
      </template>
      <template #dropdownicon>
        <i class="pi pi-map" />
      </template>
      <template #filtericon>
        <i class="pi pi-map-marker" />
      </template>
      <template #header>
        <div class="font-medium px-3 py-2">Available Countries</div>
      </template>
      <template #footer>
        <div class="p-3 flex justify-between">
          <Button label="Add New" severity="secondary" text size="small" icon="pi pi-plus" />
          <Button label="Remove All" severity="danger" text size="small" icon="pi pi-times" />
        </div>
      </template>
    </MultiSelect>
  </div>
</template>

<script setup>
import {onMounted, ref} from "vue";
// import { MultiSelect } from 'primevue/multiselect';
// import { Button } from 'primevue/button';

const props = defineProps({
  // 可以添加自定义的props,例如是否禁用组件等
  disabled: {
    type: Boolean,
    default: false
  },
   countries:{
    type: Array,

     required: true
   },
    selectedCountries:{
      type: Array,

    },
  visible:{
    type: Boolean,
    default: false

  }

});

const selectedCountries = ref([])
// 如果需要根据父组件传入的值改变内部数据结构,可以在这里处理
// 例如:
// if (props.someValue) {
//     // 对countries或者selectedCountries进行操作
// }

// 可以定义内部的方法,如果需要暴露给父组件,可以使用emits

//updateSelectedCountries名字随便,爱叫是什么叫什么,只要统一就行

const emit = defineEmits(['updateSelectedCountries']);
const emitModelValueChange = () => {
  emit('updateSelectedCountries', selectedCountries);
};
</script>
2.父组件
3.界面效果

3.为啥一定要传值呢?

因为不同的vue文件要传值,

那为什么不直写在一个组件里?

因为抽出一个组件后,可以复用组件,减少代码量,代码看起来整洁不少。。。。。。。

相关推荐
paopaokaka_luck15 分钟前
基于SpringBoot+Uniapp的健身饮食小程序(协同过滤算法、地图组件)
前端·javascript·vue.js·spring boot·后端·小程序·uni-app
90后的晨仔4 小时前
🚨XSS 攻击全解:什么是跨站脚本攻击?前端如何防御?
前端·vue.js
Ares-Wang4 小时前
JavaScript》》JS》 Var、Let、Const 大总结
开发语言·前端·javascript
90后的晨仔4 小时前
Vue 模板语法完全指南:从插值表达式到动态指令,彻底搞懂 Vue 模板语言
前端·vue.js
90后的晨仔4 小时前
Vue 3 应用实例详解:从 createApp 到 mount,你真正掌握了吗?
前端·vue.js
SY_FC5 小时前
uniapp input 聚焦时键盘弹起滚动到对应的部分
javascript·vue.js·elementui
爱吃香蕉的阿豪5 小时前
SignalR 全解析:核心原理、适用场景与 Vue + .NET Core 实战
vue.js·microsoft·c#·.netcore·signalr
koooo~6 小时前
node.js中的fs与path模块
node.js
渣渣盟6 小时前
JavaScript核心概念全解析
开发语言·javascript·es6
Carlos_sam7 小时前
OpenLayers:ol-wind之渲染风场图全解析
前端·javascript