Does react native support base64 encoded images?

前端 未结 4 2268
庸人自扰
庸人自扰 2020-12-14 14:31

Does react native support base 64 encoded images?

I tried:



        
相关标签:
4条回答
  • 2020-12-14 14:37

    I think Ramsay is wrong, react native have a fully support on base64 image. I found this

    https://facebook.github.io/react-native/docs/tabbarios.html
    

    this is a official example of how to create a iOS TabBarController, and they use a base64 image as one of the TabBar's icon.

    I think you did not specify the width and the height in the style property of the <Image/>.

    I tried to use your base64 image in my React Native Playground, and it works.

    Usage

    var base64Icon = '';
    

    and use in this way

    <Image style={{width: 100, height: 50, resizeMode: Image.resizeMode.contain, borderWidth: 1, borderColor: 'red'}} source={{uri: base64Icon}}/>
    
    0 讨论(0)
  • 2020-12-14 14:42

    Yes it is supporting.

    Try below It is tested in iOS and below version "react": "16.9.0", "react-native": "0.61.2",

    const base64Image = '...';
    <Image source={{uri: `data:image/jpeg;base64,${base64Image}`}} />
    

    If still not working. check type of image i.e. jpeg, png etc.

    Hope this help :)

    0 讨论(0)
  • 2020-12-14 14:49
     <Image
         source={{
            uri: `data:image/jpeg;base64,${this.state.barcodeImage}`,
         }}
         style={{height: 200, width: 250}}
     />
    

    notice : add style in image

    0 讨论(0)
  • 2020-12-14 14:50

    I don't think this is supported. Unless the URL contains "http" or "https", it's considered a "static" image. Picking through the code, the instantiation of the final image boils down to:

    if ([path isAbsolutePath]) {
      image = [UIImage imageWithContentsOfFile:path];
    } else {
      image = [UIImage imageNamed:path];
      if (!image) {
        image = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:path ofType:nil]];
      }
    }
    

    Step by step:

    1. If the URL is an absolute path, load it as a file
    2. Else if the image is cached (imageNamed), load that
    3. Else if the image is a relative path, load it from the app bundle

    Obviously none of that relates to base64. I've created a pull request for this feature which you can view here:

    https://github.com/facebook/react-native/pull/576

    0 讨论(0)
提交回复
热议问题