SVG 作为矢量图的一种标准格式,已经得到了各大浏览器的支持,它也成为了 Web 中矢量图的代名词。 在网页中采用 SVG 代替位图有如下好处:
画图工具能导出一个个 .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
raw-loader 可以把文本文件的内容读取出来,注入到 JavaScript 或 CSS 中去。
例如在 JavaScript 中这样写:
import svgContent from './svgs/alert.svg';
经过 raw-loader 处理后输出的代码如下:
module.exports = "<svg xmlns=\"http://www.w3.org/2000/svg\"... </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
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'] } ] } };
本实例提供项目完整代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍webpack实现热加载自动刷新的方法,包括了webpack实现热加载自动刷新的方法的使用技巧和注意事项,需要的朋友参考一下 本文介绍了webpack实现热加载自动刷新的方法,分享给大家,具体如下: 一、webpack-dev-server 一个轻量级的服务 功能:修改代码及时呈现到浏览器上。 第一步:安装 第二步:写入到依赖 第三步:修改webpack配置文件 说明:如果想指定
本文向大家介绍vue+webpack实现异步组件加载的方法,包括了vue+webpack实现异步组件加载的方法的使用技巧和注意事项,需要的朋友参考一下 8.9更新:之前想搬迁到csdn的时候由于邀请码问题迟迟没把博客转过来,所以跑去博客园了,今天发现csdn已经帮我把文章搬过来,有必要修正一下这篇文章。 写这篇文章的时候因为刚接触vue,所以捣鼓的时候有些迷糊。 ----------------/
本文向大家介绍webpack 动态批量加载文件的实现方法,包括了webpack 动态批量加载文件的实现方法的使用技巧和注意事项,需要的朋友参考一下 背景 最近笔者在工作中遇到了一个小需求: 要实现一个组件来播放帧图片 这个需求本身不复杂,但是需要在组件中一次性引入十张图片,就像下面这样: 作为一个有代码洁癖的程序员,我是不允许这种重复性代码存在滴,于是乎就尝试有没有什么简单的方法。 方法一:绕过
本文向大家介绍Webpack 实现 AngularJS 的延迟加载,包括了Webpack 实现 AngularJS 的延迟加载的使用技巧和注意事项,需要的朋友参考一下 随着你的单页应用扩大,其下载时间也越来越长。这对提高用户体验不会有好处(提示:但用户体验正是我们开发单页应用的原因)。更多的代码意味着更大的文件,直到代码压缩已经不能满足你的需求,你唯一能为你的用户做的就是不要再让他一次性下载整个应
本文向大家介绍webpack配置sass模块的加载的方法,包括了webpack配置sass模块的加载的方法的使用技巧和注意事项,需要的朋友参考一下 webpack管理的项目,我们希望用sass定义样式,为了正常编译,需要做如下配置。这里不讲webpack的入门,入门的文章,我推荐这篇《webpack入门》。 为了使用sass,我们需要安装sass的依赖包 当然了,使用样式的话,css-loader
问题内容: 我使用滑翔到一些图像加载 异步 到一些我的S,我知道它能够处理图像像或者因为它可以处理。 据我所知,加载这两种图像的方式有所不同。喜欢: 加载“正常”图像 加载SVG 而且,如果我尝试使用第一种方法加载SVG,它将无法正常工作。如果我尝试使用第二种方法加载PNG或JPG,它也将无法正常工作。 是否有使用Glide加载两种图像类型的通用方法? 我从中获取这些图像的服务器在下载之前不会告诉