vue3中v-model使用及封装下拉框组件

父子组件双向绑定

1、vue3中 v-model是:modelValue和@updat:modelValue的简写

2、父传子,通过defineProps({})接收;

3、子组件绑定父组件传递过来的值 :modelValue="modelValue",

子组件通过emit与父组件实时绑定:

const emit =defineEmits('update:modelValue')

@update:modelValue="emit('update:modelValue',$event)"

4、v-model="params.cate_id等价于v-model:modelValue="params.cate_id

v-model:modelValue中的modelValue可以换成其他名称,子组件接收也要改成相同的名字

5、v-model可以双向绑定多个值v-mode:a=" " v-model:b=" "

vue3封装下拉框组件案例:

typescript 复制代码
<!-- 父组件引入子组件 -->
<categorySelect v-model="params.cate_id"></categorySelect>

<!--子组件代码  -->
<script setup lang="ts">
import {ref} from 'vue'
import {getChannnels} from '@/api/articl'
defineProps({
    modelValue:{
        type:[Number,String]
    }
})
const emit =defineEmits(['update:modelValue'])
//分类
const CategoriesList = ref([])
const getCategories = async ()=>{
  const res = await getChannnels()
  CategoriesList.value = res.data.data
}
getCategories()
</script>
<template>
 <el-select
     :modelValue="modelValue"
     @update:modelValue="emit('update:modelValue',$event)"
      placeholder="Select"
      size="large"
      style="width: 240px"
    >
      <el-option
        v-for="item in CategoriesList"
        :key="item.id"
        :label="item.cate_name"
        :value="item.id"
      />
    </el-select>
</template>

vue2封装下拉框组件案例:

相关推荐
暗夜猎手-大魔王2 分钟前
转载--Hermes Agent 08 | Agent 的自我进化:nudge、后台审查与轨迹数据
java·前端·人工智能
IT_陈寒11 分钟前
Redis集群节点迁移把我坑惨了,这个坑你得提前绕开
前端·人工智能·后端
新酱爱学习14 分钟前
手搓 10 个 Skill 踩出来的坑,我做成了一套工程化工具链
前端·人工智能·agent
怕浪猫22 分钟前
Electron 开发实战(八):多媒体处理全解|音视频播放、录屏、FFmpeg 实战
前端·javascript·electron
恋猫de小郭23 分钟前
一个 Linux 调度器优化,让 Android 多耗 20% 的电,传音工程师如何发现问题?
android·前端·ios
kyriewen1128 分钟前
开源|Image Harvest v1.0.5:AI 智能标签 + Eagle 导出,设计师和开发者的图片工作流神器
前端·javascript·人工智能
步十人31 分钟前
【Vue】认识单文件组件与模板语法
前端·javascript·vue.js
AIFQuant39 分钟前
贵金属投资 APP 开发:实时报价、图表、提醒与交易数据全链路
开发语言·前端·websocket·金融·web app
爱吃羊的老虎41 分钟前
【JAVA】python转java:Spring Boot 如何处理 Web 请求
java·前端·spring boot·http
shuoshuohaohao42 分钟前
《JavaScript》
开发语言·前端·javascript