vue3+ts element 行政区划组件开发

该文章展示了一个Vue组件的实现,使用el-cascader进行级联选择。组件利用typescript,通过API获取行政区域数据,并处理数据以适应组件需求,支持清空、禁用、多选等特性,并在输入时动态过滤选项。
摘要由CSDN通过智能技术生成
<template>
    <div>
        <el-cascader :modelValue="modelValue" :props="innerProps" :options="options" @change="handleChange" filterable
            :show-all-levels="showAllLevels" :disabled="disabled" :placeholder="placeholder" :clearable="clearable"
            style="width:100%" @blur="onBlur" @focus="onFocus" />
    </div>
</template>

<script lang="ts" setup>
import { ref, reactive, toRaw, onMounted } from 'vue'
import type { CascaderProps } from 'element-plus'
import * as api from "./api.js";

const props = defineProps({
    modelValue: {
        type: Array,
        default: []
    },
    // 是否支持清空选项
    clearable: {
        type: Boolean,
        default: true,
    },
    // 是否多选
    multiple: {
        type: Boolean,
        default: false,
    },
    // 指定某省,传入该自治区的areacode
    designation: {
        type: String,
        default: '',
    },
    // 仅显示最后一级
    showAllLevels: {
        type: Boolean,
        default: true,
    },
    // 是否禁用
    disabled: {
        type: Boolean,
        default: false,
    },
    // 输入框占位文本
    placeholder: {
        type: String,
        default: '',
    },
    // 是否选择任意一级选项,还是最后叶子结点
    checkStrictly:{
        type: Boolean,
        default: true,
    },
    // 次级菜单的展开方式,click和hover
    expandTrigger:{
        type: String,
        default: 'click',
    },
})

const value = ref([])   //
let options: any = ref([])  //树

onMounted(() => {
    // 获取全量数据
    getAllData()
})

const emit = defineEmits(['update:modelValue', 'change'])

let selectarr = []
const handleChange = (e: any, e2: any) => {
    emit('update:modelValue', e)
    emit('change', e)
}

let firstLevel = []

async function getAllData() {
    let res = await api.SearchAdministrativeDivisions({
        queryArea: props.designation
    })
    options.value = res.data
    console.log(options.value, '---options.value');

}

function onFocus(e: any) { }
async function onBeforeFilter(e: any) {
    let res = await api.SearchAdministrativeDivisions({
        queryArea: e
    })
    const fn = (arr: any[]) => {
        arr.forEach((item, index) => {
            if (item.children && item.children.length) {
                item.children = fn(item.children)
            } else {
                if (item.children) delete item.children
            }
        })
        return arr
    }
    console.log(options, '---options');
    options.value = fn(res.data)
}

const innerProps: CascaderProps = {
    checkStrictly: props.checkStrictly,
    // lazy: true,
    value: 'areaCode',
    label: 'name',
    multiple: props.multiple,
    expandTrigger:props.expandTrigger
}

</script>
  
<style></style>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值