vue3简单封装一个下拉框选项组件
组件
<!-- 这个为选择通知类型的下拉选组件 --><template><el-select v-model="value" filterable placeholder="选择类型" clearable><el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value" /></el-select></template><script setup>import baseService from "@/service/baseService";import {onMounted, ref } from "vue";const value = ref("");const options = ref([]);onMounted(() => {baseService.get("xxxxxxxxxxx").then((res) => {res.data.map((vo) => {options.value.push({key: vo.id,label: vo.typeName,value: vo.id});});console.log("访问的接口为:xxxxxxxxxxxxx");});});</script>
应用
script
<script lang="ts">import useView from "@/hooks/useView";import {defineComponent, reactive, toRefs } from "vue";import noticeTypeSelect from "@/views/dcomponents/noticeTypeSelect.vue";export default defineComponent({components: {noticeTypeSelect},setup() {const state = reactive({dataForm: {typeId: ""}});return {...useView(state), ...toRefs(state) };},});</script>
div
<notice-type-select v-model="dataForm.typeId"></notice-type-select>
完整代码
<template><notice-type-select v-model="dataForm.typeId"></notice-type-select></template><script lang="ts">import useView from "@/hooks/useView";import {defineComponent, reactive, toRefs } from "vue";import noticeTypeSelect from "@/views/dcomponents/noticeTypeSelect.vue";export default defineComponent({components: {noticeTypeSelect},setup() {const state = reactive({dataForm: {typeId: ""}});return {...useView(state), ...toRefs(state) };},});</script>