cc网贷,甜心前妻回来吧,美甲社区门户
vue cli3 手把手教学封装svgicon组件
第一步:在src文件下新建一个放置svg文件的文件夹
第二步:在components文件下新建一个svg组件
这是一个 文件夹 专门用来存放项目里面需要使用的svg文件,比如 a.svg b.svg …
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
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组件内容请搜索移动技术网以前的文章或继续浏览下面的相关文章希望大家以后多多支持移动技术网!
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
VUE+elementui组件在table-cell单元格中绘制微型echarts图
Vue通过getAction的finally来最大程度避免影响主数据呈现问题
vue 路由懒加载中给 Webpack Chunks 命名的方法
网友评论