Convert svg to react-native-svg

后端 未结 2 1812
耶瑟儿~
耶瑟儿~ 2021-02-05 16:42

What is the easiest way to do this? I found plenty of svg to JSX converters, which is what I want, but that doesn\'t work in react-native. I need to convert the svg code to some

2条回答
  •  傲寒
    傲寒 (楼主)
    2021-02-05 17:07

    I can think of the following options. The one you use will depend on the amount of files you have to convert.

    Option 1 (few files)

    Copy-paste your svg code on this site and check the React Native checkbox. This will give you the code which you can then use with react-native-svg

    Use that output within the following code (replace the SvgComponent with what was generated):

    import React, { Component } from 'react';
    import { View } from 'react-native';
    import Svg, { Circle, Path } from 'react-native-svg';
    
    const SvgComponent = props => (
      
        
      
    );
    
    class MySVGIcon extends Component {
      render() {
        const { style } = this.props;
        const component = SvgComponent(style);
    
        return {component};
      }
    }
    
    export default MySVGIcon;
    
    

    Option 2 (many files)

    Instead of converting them, you can embed them directly in your code with react-native-remote-svg.

    For instance you can do this:

    import Image from 'react-native-remote-svg';
    
    class MyImageClass extends Component {
    
      render () {
        // Embed code or read a SVG file...
        const mySVGImage = '';
    
        return (
            
        );
      }
    }
    
    

    Option 3 (coolest option)

    It isn't free like the two other options, but it isn't expensive either. PaintCode is one of those tools that I just love. Version 3+ now supports java-script. So you could load your svg files in it, and it will spit out code that you can use in your app. The advantage here that the interface is friendlier than the first option above, and you can then animate each object inside the svg file from your code.

提交回复
热议问题