Webpack实战加载SVG的方法


Posted in Javascript onDecember 26, 2017

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

使用 svg-inline-loader

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

Javascript 相关文章推荐
对YUI扩展的Gird组件 Part-1
Mar 10 Javascript
基于jQuery的星级评分插件
Aug 12 Javascript
JavaScript中几个重要的属性(this、constructor、prototype)介绍
May 19 Javascript
浅谈javascript原型链与继承
Jul 13 Javascript
JavaScript优化专题之Loading and Execution加载和运行
Jan 20 Javascript
jQuery EasyUI Tab 选项卡问题小结
Aug 16 Javascript
Node.js+Express+MySql实现用户登录注册功能
Jul 10 Javascript
Node.js五大应用性能技巧小结(必须收藏)
Aug 09 Javascript
30分钟快速入门掌握ES6/ES2015的核心内容(下)
Apr 18 Javascript
vue项目使用.env文件配置全局环境变量的方法
Oct 24 Javascript
js中script的上下放置区别,Dom的增删改创建操作实例分析
Dec 16 Javascript
JavaScript进阶(三)闭包原理与用法详解
May 09 Javascript
vue学习教程之带你一步步详细解析vue-cli
Dec 26 #Javascript
基于vue-cli配置lib-flexible + rem实现移动端自适应
Dec 26 #Javascript
基于 flexible 的 Vue 组件:Toast -- 显示框效果
Dec 26 #Javascript
细说webpack源码之compile流程-rules参数处理技巧(2)
Dec 26 #Javascript
AngularJS实现的根据数量与单价计算总价功能示例
Dec 26 #Javascript
细说webpack源码之compile流程-rules参数处理技巧(1)
Dec 26 #Javascript
Bootstrap 模态框多次显示后台提交多次BUG的解决方法
Dec 26 #Javascript
You might like
async和DOM Script文件加载比较
2014/07/20 PHP
PHP页面转UTF-8中文编码乱码的解决办法
2015/10/20 PHP
php实现学生管理系统
2020/03/21 PHP
php与python实现的线程池多线程爬虫功能示例
2016/10/12 PHP
利用php_imagick实现复古效果的方法
2016/10/18 PHP
Yii2使用$this-&gt;context获取当前的Module、Controller(控制器)、Action等
2017/03/29 PHP
tp5框架基于Ajax实现列表无刷新排序功能示例
2020/02/10 PHP
JQuery实现倒计时按钮的实现代码
2012/03/23 Javascript
JS执行删除前的判断代码
2014/02/18 Javascript
jquery选择符快速提取web表单数据示例
2014/03/27 Javascript
javascript字符串函数汇总
2015/12/06 Javascript
javascript多物体运动实现方法分析
2016/01/08 Javascript
JavaScript的模块化开发框架Sea.js上手指南
2016/05/12 Javascript
jQuery+CSS3文字跑马灯特效的简单实现
2016/06/25 Javascript
js简单时间比较的方法
2016/08/02 Javascript
js指定步长实现单方向匀速运动
2017/07/17 Javascript
JS实现提交表单前的数字及邮箱校检功能
2017/11/13 Javascript
基于vue 添加axios组件,解决post传参数为null的问题
2018/03/05 Javascript
JavaScript常用数组操作方法,包含ES6方法
2020/05/10 Javascript
JavaScript forEach中return失效问题解决方案
2020/06/01 Javascript
vue实现导航菜单和编辑文本的示例代码
2020/07/04 Javascript
Python标准库os.path包、glob包使用实例
2014/11/25 Python
在Python中用has_key()方法查找键是否存在的教程
2015/05/21 Python
python多线程socket编程之多客户端接入
2017/09/12 Python
PyQt5每天必学之切换按钮
2020/08/20 Python
Python使用matplotlib绘制Logistic曲线操作示例
2019/11/28 Python
Python requests模块安装及使用教程图解
2020/06/30 Python
python 实现朴素贝叶斯算法的示例
2020/09/30 Python
整理的15个非常有用的 HTML5 开发教程和速查手册
2011/10/18 HTML / CSS
计算机应用专业学生的自我评价分享
2013/11/03 职场文书
应届生污水处理求职信
2013/11/06 职场文书
高中运动会入场词
2014/02/14 职场文书
2014个人年度工作总结范文
2014/12/24 职场文书
2015年社区服务活动总结
2015/03/25 职场文书
消费者投诉书范文
2015/07/02 职场文书
德劲DE1108畅想
2021/04/22 无线电