9

我目前正在使用默认的“Material Design Icons”构建一个 vuetifyjs-app。在生产版本中,我只使用了这种字体的 2 个图标(由 vuetify-component 芯片使用)。

按照建议,我将完整的图标字体包含在

<link href="https://cdn.jsdelivr.net/npm/@mdi/font@3.x/css/materialdesignicons.min.css" rel="stylesheet">

但是生产构建这迫使用户下载几乎 0.5MB 的数据,仅用于 2 个图标。有没有办法:

  • 在 CDN 请求中仅包含所需的图标或
  • 使用 Tree-Shaking 在主 CSS 文件中只包含需要的图标?(我正在使用 parcel.js 构建器)
4

1 回答 1

16

我们建议尽可能使用@mdi/js。这提供了一个 ES 模块,它导出图标集中每个图标的 SVG 路径并支持 treeshaking。您只需将图标字符串传递给 SVG 路径元素,或者在这种情况下,v-icon如果您在 Vuetify 配置中指定图标字体,则可以直接将其传递给iconfont: 'mdiSvg'

安装

npm install @mdi/js

用法

<template>
  <v-icon>{{ mdiCheck }}</v-icon>
</template>

<script>
  import { mdiCheck } from '@mdi/js'

  export default {
    data: () => ({
      mdiCheck,
    }),
  }
</script>

您可以在此处阅读有关与 Vuetify 集成的更多信息:https ://vuetifyjs.com/en/customization/icons#install-material-design-icons-js-svg

于 2019-08-19T08:20:40.027 回答