浅析vue cli3 封装Svgicon组件正确姿势(推荐)
2020-04-28 12:04
141 查看
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
- 需要的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组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
相关文章推荐
- vue-cli3引入svg-icon正确姿势
- Vue 爬坑之路(九)—— 用正确的姿势封装组件
- Toolbar NavigationIcon正确的使用姿势
- 正确姿势使用vue cli3配置多页项目
- v-for中取子组件的ref并调用其方法的正确姿势,避免方法出现 is not a function,或者是undefined
- 在Flutter中嵌入Native组件的正确姿势
- vue-cli3 svg组件封装
- Vue 将 IconFont 封装成组件
- 抵抗勒索病毒的正确姿势——不要上来就封端口! 推荐
- RN 入门之-组件创建的最新正确姿势(⊙o⊙)哦
- 阿里云centos7使用yum安装mysql的正确姿势(推荐)
- 把Fusioncharts封装成Ext组件的思路
- native-base中icon不能正确显示
- 用vscode写markdown的正确姿势
- ImageView 正确使用姿势
- axios.js 推荐的ajax组件请求API
- hhvm的正确安装姿势 http://dl.hhvm.com 镜像
- vue 封装 radio 组件,纯css手写,需修改样式可自制
- 使用缓存的正确姿势
- Git远程操作的正确姿势