svgr 简介

百度搜索了一下 SVGR ,结果没搜索到一条相关的内容。因此我决定写一系列关于 SVGR 教程的文章,本文是第一篇,SVGR 入门简介篇。 svgr 是一个将SVG转换为React组件,svgr 由 JavaScript 实现。整个文档也非常的小,目前最新版本为v0.5.0,已开源在github上。 svgr 官网地址:https://github.com/smooth-code/svgr。截止发稿前,svgr 已获得上千的 star。 svgr 包含一下核心关键词:svg2react、svg-to-react、svg、svgo、react、react-svg、react-svg-creator、svg-react、webpack-loader、webpack、inline-svg。 安装svgr npm install svgrhttp://www.anbomei.com/35df/de20d04cc532.html 基本用法 看一个icon.svg例子: <?xml version="1.0" encoding="UTF-8"?> <svg width="48px" height="1px" viewBox="0 0 48 1" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> <!-- Generator: Sketch 46.2 (44496) - http://www.anbomei.com/d40a/f841f06cd39d.htmlhttphttp://www.anbomei.com/38e4/ee0db1366c22.html://www.bohemiancoding.com/sketch -http://www.anbomei.com/307d/707e5ff4f6be.html-> <title>Rectangle 5</title> <desc>Created with Sketch.</desc> <defs></defs> <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd"> <g http://www.anbomei.com/6813/91b2dbe29d89.htmlid="19-Separator" transform="translate(-129.000000, -156.000000)" fill="#063855"> <g id="Controls/Settings" transform="translate(80.000000, 0.000000)"> http://www.anbomei.com/2efc/e223e0e932b6.html <g id="Content" transform=&qhttp://www.anbomei.com/00ea/42c2de369276.htmluot;translate(0.000000, 64.000000)"> <g id="Group" transform="translate(24.000000, 56.000000)"> <g id="Group-2"> <rect id="Rectangle-5" x="25" y="36" widthhttp://www.anbomei.com/322e/dce6736bd2fe.html="48" height="1"></rect> </g> </g> </g> </g> </g> </g> </svg> 运行SVGR: svgr --no-semi --icon --replace-attr-value "#063855=currentColor" icon.svg 最后被转换成了React 代码: import React from "react" // 业余草;www.xttblog.com const SvgComponent = props => ( <svg width="1em" height="1em" viewBox="0 0 48 1" {...props}> <path d="M0 0h48v1H0z" fill="currentColor" fillRule="evenodd" /> </svg> ) export default SvgComponenthttp://www.anbomei.com/674f/d38b32dfdee7.html svgr 还有很多开箱即用的功能,我们下章再说。 最后,欢迎关注我的个人微信公众号:业余http://www.anbomei.com/3aa9/ebc1e694dbd3.html草(yyucao)!