Vue将Element Plus 进行自定义封装

简介: Vue将Element Plus 进行自定义封装

一、前言



Element Plus 是一套基于 Vue 3.0 的桌面端组件库,它可以很方便地实现各种样式的组件,就连图标选择器这样的小功能也不在话下。不过今天我们要做的是——封装 Element Plus 的图标选择器。


二、安装


安装 Element Plus:

npm i element-plus -S

三、预览


先看一下我们要实现的效果:


https://cdn.jsdelivr.net/gh/xugaoyi/image_store/blog/20210823232623.gif


四、封装


首先我们需要在 `main.js` 中引入 `Element Plus`:


import { createApp } from 'vue'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
createApp(App).use(ElementPlus).mount('#app')

然后我们要封装一个图标选择器组件,这里我们命名为 `IconPicker`,并将其注册为全局组件:


import { Upload, Dialog, RadioGroup, RadioButton, Input, Button } from 'element-plus'
import { computed, defineComponent, ref, watch } from 'vue'
export default defineComponent({
  name: 'IconPicker',
  components: {
    ElUpload: Upload,
    ElDialog: Dialog,
    ElRadioGroup: RadioGroup,
    ElRadioButton: RadioButton,
    ElInput: Input,
    ElButton: Button
  },
  props: {
    value: {
      type: String,
      required: true
    },
    prefixIcon: {
      type: String,
      default: 'el-icon-more'
    }
  },
  emits: ['update:value'],
  setup(props, { emit }) {
    const showIconPicker = ref(false) // 是否显示图标选择器
    const searchText = ref('') // 搜索文本框的值
    const searchResults = ref([]) // 搜索结果
    // 所有图标名称列表
    const icons = [
      'el-icon-info',
      'el-icon-warning',
    // ...
      'el-icon-close'
    ]
    // 根据搜索文本过滤图标名称
    const filteredIcons = computed(() => {
      return icons.filter(icon => icon.includes(searchText.value))
    })
    // 根据搜索文本过滤图标分类
    const iconCategories = computed(() => {
      const categories = []
      for (let i = 0; i < filteredIcons.value.length; i++) {
        const icon = filteredIcons.value[i]
        const category = icon.split('-')[0]
        if (!categories.includes(category)) {
          categories.push(category)
        }
      }
      return categories
    })
    // 根据当前搜索结果生成分类列表
    const categoryList = computed(() => {
      const list = []
      for (let i = 0; i < iconCategories.value.length; i++) {
        const category = iconCategories.value[i]
        const icons = filteredIcons.value.filter(icon => icon.split('-')[0] === category)
        list.push({
          name: category,
          icons
        })
      }
      return list
    })
    // 当搜索文本发生变化时重新过滤图标
    watch(searchText, () => {
      searchResults.value = filteredIcons.value
    })
    // 打开图标选择器
    const openIconPicker = () => {
      showIconPicker.value = true
    }
    // 关闭图标选择器
    const closeIconPicker = () => {
      showIconPicker.value = false
    }
    // 选择一个图标
    const selectIcon = (icon) => {
      emit('update:value', icon)
      closeIconPicker()
    }
    return {
      showIconPicker,
      searchText,
      searchResults,
      categoryList,
      openIconPicker,
      closeIconPicker,
      selectIcon
    }
  }
})


五、使用    


在需要使用图标选择器的地方,我们只需要通过 `v-model` 绑定一个变量即可:


<template>
  <div>
    <el-input v-model="icon" readonly />
    <el-button type="primary" @click="openIconPicker">选择图标</el-button>
    <icon-picker v-model="icon" />
  </div>
</template>
<script>
import IconPicker from './components/IconPicker.vue'
import { defineComponent, ref } from 'vue'
export default defineComponent({
  name: 'App',
  components: {
    IconPicker
  },
  setup() {
    const icon = ref('el-icon-info')
    return {
      icon
    }
  }
})
</script>


最后我们只需要在 `main.js` 中引入我们封装的 `IconPicker` 组件:


import { createApp } from 'vue'
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import App from './App.vue'
import IconPicker from './components/IconPicker.vue'
const app = createApp(App)
app.use(ElementPlus)
app.component('IconPicker', IconPicker)
app.mount('#app')

六、总结


至此,我们已经完成了一个图标选择器的封装工作。封装这个小组件的意义不在于实现这个功能,更在于让我们了解如何封装一个 Vue 组件。在开发中,不管是做大型应用还是小型应用,都离不开组件的使用和封装,应该都能收到很好的效果。

相关文章
|
17天前
|
存储 JavaScript 前端开发
基于 ant-design-vue 和 Vue 3 封装的功能强大的表格组件
VTable 是一个基于 ant-design-vue 和 Vue 3 的多功能表格组件,支持列自定义、排序、本地化存储、行选择等功能。它继承了 Ant-Design-Vue Table 的所有特性并加以扩展,提供开箱即用的高性能体验。示例包括基础表格、可选择表格和自定义列渲染等。
|
7月前
vue3+Ts 二次封装ElementUI form表单
【10月更文挑战第8天】
587 59
|
6月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
180 64
|
6月前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
235 64
|
6月前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
7月前
|
JavaScript API
vue3知识点:自定义hook函数
vue3知识点:自定义hook函数
59 2
|
7月前
|
Web App开发 JavaScript 数据可视化
vue3扩展echart封装为组件库-快速复用
vue3扩展echart封装为组件库-快速复用
309 7
|
7月前
|
JavaScript 前端开发 API
vue3中常用插件的使用方法:按需引入自定义组件,自动导入依赖包,自动生成路由,自动生成模拟数据
vue3中常用插件的使用方法:按需引入自定义组件,自动导入依赖包,自动生成路由,自动生成模拟数据
1466 0
|
7月前
|
JavaScript 前端开发 Java
vue2知识点:Vue封装的过度与动画
vue2知识点:Vue封装的过度与动画
50 0
|
7月前
|
人工智能 JavaScript 程序员
vue中内置指令v-model的作用和常见使用方法介绍以及在自定义组件上支持
vue中内置指令v-model的作用和常见使用方法介绍以及在自定义组件上支持
880 0