欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Webpack实战加载SVG的方法

程序员文章站 2022-11-29 20:21:51
svg 作为矢量图的一种标准格式,已经得到了各大浏览器的支持,它也成为了 web 中矢量图的代名词。 在网页中采用 svg 代替位图有如下好处: svg 相对于位...

svg 作为矢量图的一种标准格式,已经得到了各大浏览器的支持,它也成为了 web 中矢量图的代名词。 在网页中采用 svg 代替位图有如下好处:

  1. svg 相对于位图更清晰,在任意缩放的情况下后不会破坏图形的清晰度,svg 能方便地解决高分辨率屏幕下图像显示不清楚的问题。
  2. 在图形线条比较简单的情况下,svg 文件的大小要小于位图,在扁平化 ui 流行的今天,多数情况下 svg 会更小。
  3. 图形相同的 svg 比对应的高清图有更好的渲染性能。
  4. svg 采用和 html 一致的 xml 语法描述,灵活性很高。

画图工具能导出一个个 .svg 文件,svg 的导入方法和图片类似,既可以像下面这样在 css 中直接使用:

body {
 background-image: url(./svgs/activity.svg);
}

也可以在 html 中使用:

<img src="./svgs/activity.svg"/>

也就是说可以直接把 svg 文件当成一张图片来使用,方法和使用图片时完全一样。 所以在3-19 加载图片 中介绍的两种方法 使用 file-loader 和 使用 url-loader 对 svg 来说同样有效,只需要把 loader test 配置中的文件后缀改成 .svg ,代码如下:

module.exports = {
 module: {
  rules: [
   {
    test: /\.svg/,
    use: ['file-loader']
   }
  ]
 },
};

由于 svg 是文本格式的文件,除了以上两种方法外还有其它方法,下面来一一说明。

使用 raw-loader

可以把文本文件的内容读取出来,注入到 javascript 或 css 中去。

例如在 javascript 中这样写:

import svgcontent from './svgs/alert.svg';

经过 raw-loader 处理后输出的代码如下:

复制代码 代码如下:

module.exports = "<svg xmlns=\""... </svg>" // 末尾省略 svg 内容
 

也就是说 svgcontent 的内容就等于字符串形式的 svg,由于 svg 本身就是 html 元素,在获取到 svg 内容后,可以直接通过以下代码将 svg 插入到网页中:

window.document.getelementbyid('app').innerhtml = svgcontent;

使用 raw-loader 时相关的 webpack 配置如下:

module.exports = {
 module: {
  rules: [
   {
    test: /\.svg$/,
    use: ['raw-loader']
   }
  ]
 }
};

由于 raw-loader 会直接返回 svg 的文本内容,并且无法通过 css 去展示 svg 的文本内容,因此采用本方法后无法在 css 中导入 svg。 也就是说在 css 中不可以出现 background-image: url(./svgs/activity.svg) 这样的代码,因为 background-image: url(<svg>...</svg>) 是不合法的。

本实例提供项目完整代码

使用 svg-inline-loader

和上面提到的 raw-loader 非常相似, 不同在于 svg-inline-loader 会分析 svg 的内容,去除其中不必要的部分代码,以减少 svg 的文件大小。

在使用画图工具如 adobe illustrator、sketch 制作 svg 后,在导出时这些工具会生成对网页运行来说不必要的代码。 举个例子,以下是 sketch 导出的 svg 的代码:

<svg class="icon" verison="1.1" xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewbox="0 0 24 24"
   stroke="#000">
 <circle cx="12" cy="12" r="10"/>
</svg>

被 svg-inline-loader 处理后会精简成如下:

<svg viewbox="0 0 24 24" stroke="#000"><circle cx="12" cy="12" r="10"/></svg>

也就是说 svg-inline-loader 增加了对 svg 的压缩功能。

使用 svg-inline-loader 时相关的 webpack 配置如下:

module.exports = {
 module: {
  rules: [
   {
    test: /\.svg$/,
    use: ['svg-inline-loader']
   }
  ]
 }
};

本实例提供项目完整代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。