浅析vue cli3 封装Svgicon组件正确姿势(推荐)


Posted in Javascript onApril 27, 2020

vue cli3 手把手教学封装Svgicon组件

第一步:在src文件下新建一个放置svg文件的文件夹

浅析vue cli3 封装Svgicon组件正确姿势(推荐)

第二步:在components文件下新建一个Svg组件

这是一个 文件夹 专门用来存放项目里面需要使用的svg文件,比如 a.svg b.svg …

浅析vue cli3 封装Svgicon组件正确姿势(推荐)

svg组件源码

<template>
 <svg :class="svgClass" aria-hidden="true">
  <use :xlink:href="iconName"></use>
 </svg>
</template>

<script type="text/ecmascript-6">
/* icon组件实现自动引入 ../../Icons/svg 下面所有的图标了
*之后我们就要使用到 webpack 的 require.context。
很多人对于 require.context可能比较陌生,
直白的解释就是require.context("./test", false, /.test.js$/); 
这行代码就会去 test 文件夹(不包含子目录)
下面的找所有文件名以 .test.js 结尾的文件能被 require 的文件。 
更直白的说就是 我们可以通过正则匹配引入相应的文件模块*/
const requireAll = requireContext => requireContext.keys().map(requireContext)
const req = require.context('../../Icons/svg', false, /\.svg$/)
requireAll(req)
export default {
 name: 'Svgicon',
 props: {
  iconClass: {
   type: String,
   required: true
  },
  className: {
   type: String
  }
 },
 computed: {
  iconName () {
   return `#icon-${this.iconClass}`
  },
  svgClass () {
   if (this.className) {
    return 'svg-icon ' + this.className
   } else {
    return 'svg-icon'
   }
  }
 }
}
</script>

<style>
.svg-icon {
   width: 1em;
   height: 1em;
   vertical-align: -0.15em;
   fill: currentColor;
   overflow: hidden;
 }
</style>

第三步:配置vue.config.js

  • 需要的loader
  • npm i svg-sprite-loader -D
chainWebpack: config => {
  const svgRule = config.module.rule('svg')
  svgRule.uses.clear()
  svgRule
   .use('svg-sprite-loader')
   .loader('svg-sprite-loader')
   .options({
    symbolId: 'icon-[name]'
   })
}

 以上就配置完毕

注:未注册组件在人口文件全局注册即可使用(main.js)

到此这篇关于浅析vue cli3 封装Svgicon组件正确姿势(推荐)的文章就介绍到这了,更多相关vue cli3 Svgicon组件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
js弹出框轻量级插件jquery.boxy使用介绍
Jan 15 Javascript
jquery Tab效果和动态加载的简单实例
Dec 11 Javascript
浏览器缩放检测的js代码
Sep 28 Javascript
node.js中RPC(远程过程调用)的实现原理介绍
Dec 05 Javascript
javascript实现回车键提交表单方法总结
Jan 10 Javascript
js仿百度切换皮肤功能(html+css)
Jul 10 Javascript
JS实现iframe自适应高度的方法示例
Jan 07 Javascript
详解JavaScript数组过滤相同元素的5种方法
May 23 Javascript
微信小程序 功能函数小结(手机号验证*、密码验证*、获取验证码*)
Dec 08 Javascript
微信小程序自定义组件实现环形进度条
Nov 17 Javascript
微信小程序 腾讯地图显示偏差问题解决
Jul 27 Javascript
javascript解析json格式的数据方法详解
Aug 07 Javascript
react组件基本用法示例小结
Apr 27 #Javascript
react基本安装与测试示例
Apr 27 #Javascript
使用konva和vue-konva库实现拖拽滑块验证功能
Apr 27 #Javascript
JS浏览器BOM常见操作实例详解
Apr 27 #Javascript
Vue CLI3移动端适配(px2rem或postcss-plugin-px2rem)
Apr 27 #Javascript
js HTML DOM EventListener功能与用法实例分析
Apr 27 #Javascript
JS严格模式原理与用法实例分析
Apr 27 #Javascript
You might like
thinkphp5+layui实现的分页样式示例
2019/10/08 PHP
JS面向对象、prototype、call()、apply()
2009/05/14 Javascript
jquery事件重复绑定的快速解决方法
2014/01/03 Javascript
node.js中的fs.symlink方法使用说明
2014/12/15 Javascript
JavaScript中string转换成number介绍
2014/12/31 Javascript
js实现简单鼠标跟随效果的方法
2015/04/10 Javascript
js焦点文字滚动效果代码分享
2015/08/25 Javascript
angular学习之ngRoute路由机制
2017/04/12 Javascript
js实现Tab选项卡切换效果
2020/07/17 Javascript
nodejs读取本地中文json文件出现乱码解决方法
2018/10/10 NodeJs
vue.js页面加载执行created,mounted的先后顺序说明
2020/11/07 Javascript
[53:38]OG vs LGD 2018国际邀请赛淘汰赛BO3 第三场 8.26
2018/08/30 DOTA
python 开发的三种运行模式详细介绍
2017/01/18 Python
python实现简单登陆流程的方法
2018/04/22 Python
python3+PyQt5实现文档打印功能
2018/04/24 Python
python项目对接钉钉SDK的实现
2019/07/15 Python
python读取大文件越来越慢的原因与解决
2019/08/08 Python
python基于json文件实现的gearman任务自动重启代码实例
2019/08/13 Python
学python安装的软件总结
2019/10/12 Python
Python jieba库用法及实例解析
2019/11/04 Python
Python小整数对象池和字符串intern实例解析
2020/03/21 Python
pycharm下配置pyqt5的教程(anaconda虚拟环境下+tensorflow)
2020/03/25 Python
keras读取h5文件load_weights、load代码操作
2020/06/12 Python
Python文件操作及内置函数flush原理解析
2020/10/13 Python
python爬虫beautifulsoup解析html方法
2020/12/07 Python
详解Python Celery和RabbitMQ实战教程
2021/01/20 Python
Interrail法国:乘火车探索欧洲,最受欢迎的欧洲铁路通票
2019/08/27 全球购物
Oracle里面常用的数据字典有哪些
2014/02/14 面试题
童装店创业计划书
2014/01/09 职场文书
学校宣传标语
2014/06/18 职场文书
幸福家庭标语
2014/06/27 职场文书
活动总结范文
2014/08/30 职场文书
企业法人任命书
2015/09/21 职场文书
Python基础之常用库常用方法整理
2021/04/30 Python
Python手拉手教你爬取贝壳房源数据的实战教程
2021/05/21 Python
CSS元素定位之通过元素的标签或者元素的id、class属性定位详解
2022/09/23 HTML / CSS