Example code of vue icon selector

Example code of vue icon selector

Source: http://www.ruoyi.vip/

import Vue from 'vue'
import SvgIcon from '@/components/SvgIcon' // svg component
 
// register globally
Vue.component('svg-icon', SvgIcon)
 
const req = require.context('./svg', false, /\.svg$/)
const requireAll = requireContext => requireContext.keys().map(requireContext)
requireAll(req) 

# replace default config
 
# multipass: true
# full: true
 
plugins:
 
  # - name
  #
  # or:
  # - name: false
  # - name: true
  #
  # or:
  # - name:
  # param1: 1
  # param2: 2
 
-removeAttrs:
    attrs:
      - 'fill'
      - 'fill-rule' 

<template>
  <div v-if="isExternal" :style="styleExternalIcon" class="svg-external-icon svg-icon" v-on="$listeners" />
  <svg v-else :class="svgClass" aria-hidden="true" v-on="$listeners">
    <use :xlink:href="iconName" rel="external nofollow" />
  </svg>
</template>
 
<script>
// doc: https://panjiachen.github.io/vue-element-admin-site/feature/component/svg-icon.html#usage
import { isExternal } from '@/utils/validate'
 
export default {
  name: 'SvgIcon',
  props: {
    iconClass: {
      type: String,
      required: true
    },
    className: {
      type: String,
      default: ''
    }
  },
  computed: {
    isExternal() {
      return isExternal(this.iconClass)
    },
    iconName() {
      return `#icon-${this.iconClass}`
    },
    svgClass() {
      if (this.className) {
        return 'svg-icon ' + this.className
      } else {
        return 'svg-icon'
      }
    },
    styleExternalIcon() {
      return {
        mask: `url(${this.iconClass}) no-repeat 50% 50%`,
        '-webkit-mask': `url(${this.iconClass}) no-repeat 50% 50%`
      }
    }
  }
}
</script>
 
<style scoped>
.svg-icon {
  width: 1em;
  height: 1em;
  vertical-align: -0.15em;
  fill: currentColor;
  overflow: hidden;
}
 
.svg-external-icon {
  background-color: currentColor;
  mask-size: cover!important;
  display: inline-block;
}
</style> 

<!-- @author zhengjie -->
<template>
  <div class="icon-body">
    <el-input v-model="name" style="position: relative;" clearable placeholder="Please enter the icon name" @clear="filterIcons" @input.native="filterIcons">
      <i slot="suffix" class="el-icon-search el-input__icon" />
    </el-input>
    <div class="icon-list">
      <div v-for="(item, index) in iconList" :key="index" @click="selectedIcon(item)">
        <svg-icon :icon-class="item" style="height: 30px;width: 16px;" />
        <span>{{ item }}</span>
      </div>
    </div>
  </div>
</template>
 
<script>
import icons from './requireIcons'
export default {
  name: 'IconSelect',
  data() {
    return {
      name: '',
      iconList: icons
    }
  },
  methods: {
    filterIcons() {
      this.iconList = icons
      if (this.name) {
        this.iconList = this.iconList.filter(item => item.includes(this.name))
      }
    },
    selectedIcon(name) {
      this.$emit('selected', name)
      document.body.click()
    },
    reset() {
      this.name = ''
      this.iconList = icons
    }
  }
}
</script>
 
<style rel="stylesheet/scss" lang="scss" scoped>
  .icon-body {
    width: 100%;
    padding: 10px;
    .icon-list {
      height: 200px;
      overflow-y: scroll;
      div {
        height: 30px;
        line-height: 30px;
        margin-bottom: -5px;
        cursor: pointer;
        width: 33%;
        float: left;
      }
      span {
        display: inline-block;
        vertical-align: -0.15em;
        fill: currentColor;
        overflow: hidden;
      }
    }
  }
</style> 

This is the end of this article about vue icon selector. For more relevant vue selector content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Detailed explanation of how to use the Vue date time picker component
  • How to implement variable expression selector in Vue
  • A brief discussion on the pitfalls of Vue using Cascader cascade selector data echo
  • Vue implements multi-label selector
  • Vue sample code for implementing time selector with Vant
  • mpvue WeChat applet multi-column selector usage to achieve province and city selection

<<:  Understand the rendering process of HTML pages in preparation for learning front-end performance optimization (continued)

>>:  MySQL Full-text Indexing Guide

Recommend

JS code to achieve page switching effect

This article example shares the specific code of ...

Chinese and English font name comparison table (including Founder and Arphic)

In CSS files, we often see some font names become...

Quickly solve the problem of slow and stuck opening of input[type=file]

Why is it that when the input tag type is file an...

MySql5.7.21 installation points record notes

The downloaded version is the Zip decompression v...

5 Simple XHTML Web Forms for Web Design

Simple XHTML web form in web design 5. Technique ...

The most common mistakes in HTML tag writing

We better start paying attention, because HTML Po...

Simple use of Vue vee-validate plug-in

Table of contents 1. Installation 2. Import 3. De...

VUE + OPENLAYERS achieves real-time positioning function

Table of contents Preface 1. Define label style 2...

Implementation of element shuttle frame performance optimization

Table of contents background Solution New Questio...

SQL statements in Mysql do not use indexes

MySQL query not using index aggregation As we all...

Detailed explanation of the sticky position attribute in CSS

When developing mobile apps, you often encounter ...

Detailed explanation of Mysql communication protocol

1.Mysql connection method To understand the MySQL...

How to delete table data in MySQL

There are two ways to delete data in MySQL, one i...

Five delay methods for MySQL time blind injection

Five delay methods for MySQL time blind injection...