vue2如何二次封装表单控件如input, select等

需求

项目需要做一个城市选择器,数据来源公司的后端,要求用级联选择,使用的el-cascader

思路

二次封装要尽可能保留原有的组件prop,用法尽量保持和el-cascader一致,所以采用透传的方式传递prop

javascript 复制代码
<template>
  <div class="container" >
    <el-cascader
      :options="areaOptions"
      style="width: 100%"
      clearable
      ref="cascader"
      :value="value"
      @input="handleChange"
      v-on="$listeners"
      v-bind="$attrs"
    />
  </div>
</template>
<script>
import { findListByParentId } from '@/api/area/area'
export default {
  name: 'regionCascader',
  props: {
    value: {
      type: Array,
      default: () => []
    },
    disabledFunc: {
      // 这里是判断选项是否禁用的方法
      type: Function,
      default: (opts, level) => {
        return false
      }
    }
  },
  data() {
    return {
      options: []
    }
  },
  computed: {
    areaOptions() {
      const setOptions = (opts, level) => {
        return opts.map(opt => {
          if (opt?.children?.length) {
            opt.children = setOptions(opt.children, level + 1)
          }
          const param = {
            ...opt,
            value: opt.id,
            label: opt.areaName,
            disabled: this.disabledFunc(opt, level)
          }
          return param
        })
      }
      return setOptions(this.options, 0)
    }
  },
  mounted() {
    this.getList()
  },
  methods: {
    handleChange(e) {
      this.$emit('input', e)
    },
    getList() {
      // 这里放获取数据的逻辑
    },

    getCheckedNodes() {
      return this.$refs.cascader.getCheckedNodes()
    }
  }
}
</script>
<style scoped>
.container{
   width: 100%;
}
</style>

后话

在VUE2中 2.6版本以后可以改为如下,去掉划线代码

在2.6版本以前,$attrs是不会获取到value字段,所以导致透传不进去,必须显示声明props.value

相关推荐
chxii14 分钟前
2.9 插槽
前端·javascript·vue.js
姑苏洛言1 小时前
扫码点餐小程序产品需求分析与功能梳理
前端·javascript·后端
Freedom风间1 小时前
前端必学-完美组件封装原则
前端·javascript·设计模式
江城开朗的豌豆1 小时前
React表单控制秘籍:受控组件这样玩就对了!
前端·javascript·react.js
一枚前端小能手1 小时前
📋 代码片段管理大师 - 5个让你的代码复用率翻倍的管理技巧
前端·javascript
国家不保护废物1 小时前
Web Worker 多线程魔法:告别卡顿,轻松实现图片压缩!😎
前端·javascript·面试
接着奏乐接着舞。2 小时前
如何在Vue中使用拓扑图功能
前端·javascript·vue.js
老华带你飞2 小时前
生产管理ERP系统|物联及生产管理ERP系统|基于SprinBoot+vue的制造装备物联及生产管理ERP系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·论文·制造·毕设·生产管理erp系统
阳先森2 小时前
Vue3 Proxy 为何不直接返回target[key],选用Reflect
前端·vue.js
ONE_Gua2 小时前
魔改chromium源码——解除 iframe 的同源策略
前端·后端·浏览器