中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue怎么用自定義組件的方式引入圖標

發布時間:2022-10-13 11:31:48 來源:億速云 閱讀:180 作者:iii 欄目:開發技術

這篇“Vue怎么用自定義組件的方式引入圖標”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Vue怎么用自定義組件的方式引入圖標”文章吧。

搭建環境

這里通過@vue/cli 4.5.13新建項目,并且需要安裝依賴svg-sprite-loader,用來處理對應的svg圖標,方便我們使用。

安裝: npm install --save-dev svg-sprite-loader

配置vue.config.js

在安裝svg-sprite-loader后,新建vue.config.js來配置依賴:

// vue.config.js
const { resolve } = require("path")

module.exports = {
  chainWebpack(config) {
    config
      .module
      .rule("svg")
      .exclude
      .add(resolve("src/icons"))
      .end()
    config
      .module
      .rule("icons")
      .test(/.svg$/)
      .include
      .add(resolve("src/icons"))
      .end()
      .use("svg-sprite-loader")
      .loader("svg-sprite-loader")
      .options({
        symbolId: "icon-[name]"
      })
  }
}

這里通過chainWebpack來做了兩項配置:

  • 第一個是讓原來的其他處理svg的依賴不處理src/icons下我們的自定義圖標文件

  • 通過svg-sprite-loader來處理自定義的圖標文件,options里面的設置表示,生成的svg的symbolId為icon和文件名的拼接。

新建圖標組件

在components目錄下新建一個SvgIcon.vue文件:

<template>
  <i>
    <!-- aria-hidden, 幫助殘障人士閱讀(設備讀取內容時會跳過這個標簽以免混淆) -->
    <svg aria-hidden="true" :width="size" :height="size" :fill="fillColor">
      <use :xlink:href="iconName" rel="external nofollow" ></use>
    </svg>
  </i>
</template>

<script>
import { PropType, toRefs } from "vue"

export default {
  props: {
    size: {
      type: Number as PropType<number>,
      default: 14
    },
    fillColor: {
      type: String as PropType<string>,
      default: "#000"
    },
    iconName: {
      type: String as PropType<string>,
      required: true
    }
  },
  setup(props: any) {
    const { size, fillColor, iconName: _iconName } = toRefs(props)
    const iconName = `#${_iconName.value}`

    return {
      size,
      fillColor,
      iconName
    }
  }
}
</script>

然后,新建一個icons目錄,并且新建一個index文件,用來掛在組件和引入svg圖標:

// index.ts
import SvgIcon from "@/components/SvgIcon.vue"
import { App } from "vue"

export default (app: App) => {
  app.component("svg-icon", SvgIcon)
}

const ctx = require.context("./svg", false, /.svg$/)
const requestAll = (ctx: __WebpackModuleApi.RequireContext) => ctx.keys().forEach(ctx)

requestAll(ctx)
// main.ts
import { createApp } from "vue"
import App from "./App.vue"
import installSvgIcon from "@/icons/index"

const app = createApp(App)

installSvgIcon(app)
app.mount("#app")

這個文件做了兩件事:

  1. 通過導出一個方法來掛載全局組件svg-icon;

  2. 通過require.context來實現自動化引入svg目錄下的圖標文件。

使用組件

首先,我們要在icons/svg目錄下存放svg圖標文件(在iconfont上找自己需要的);

然后,就可以在其他地方使用啦:

<template>
  <img alt="Vue logo" src="./assets/logo.png">
  <svg-icon icon-name="icon-dashboard"></svg-icon>
  <HelloWorld msg="Welcome to Your Vue.js + TypeScript App"/>
</template>

直接通過組件svg-icon的方式引入,然后傳入icon-name即可,icon-name的值由icon拼接svg文件名組成。

以上就是關于“Vue怎么用自定義組件的方式引入圖標”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

喀喇沁旗| 汤原县| 兴国县| 澜沧| 柞水县| 丹棱县| 富平县| 拉孜县| 墨玉县| 蕉岭县| 青冈县| 共和县| 介休市| 永兴县| 玛纳斯县| 定南县| 云南省| 桐乡市| 托克逊县| 威宁| 沭阳县| 桦南县| 七台河市| 林口县| 隆昌县| 临邑县| 横峰县| 禹城市| 理塘县| 福鼎市| 湛江市| 庆元县| 吐鲁番市| 双桥区| 册亨县| 华蓥市| 株洲县| 宜都市| 喀喇沁旗| 全州县| 辽中县|