如何使用Vuejs在HTML中显示MySQL blob图像?

7

我有一个像这样的vue文件:

export default {
 data(){
  return{
            info: {
                name: '',
                image: '',
              
            },
            errors: []
  }
 },
  
  created: function(){
        this.getInfo();
  },
  
  methods: {
        getInfo: function(){
              this.info.name = response.data.results[0].name;
              this.info.image = response.data.results[0].image;
        }
  }
}

我将从这个文件中传递数据到一个子Vue组件。子组件如下所示:

<template>
    <div class="ui items">
        <div class="item">
            <div class="ui small image">
                {{info.image}}
            </div>
        </div>
    </div>
  
</template>

<script>
export default{

    props:['info']

}
</script>

我的图像以blob的形式存储在MySQL数据库中。当我运行应用程序时,UI上显示的图像是二进制数据。对象看起来像这样,

图像的JSON响应

有人可以帮助我显示图像吗?非常感谢!

3个回答

8
你需要的是一个data url。你需要将字节数组转换为base64格式。无法使用原始字节。也许可以在计算属性中使用其中一种字节数组转换为base64的函数来完成这个操作。
<img :src="dataUrl">

行为(未经测试!)

computed : {
    dataUrl(){
        return 'data:image/jpeg;base64,' + btoa(
            new Uint8Array(this.info.image)
            .reduce((data, byte) => data + String.fromCharCode(byte), '')
        );
    }
}

审视自己的良心。这真的不是一个好主意 :-) 将图像作为JSON编码的字节数组发送是我从未见过的事情,猜测会比二进制图像在传输中大约10倍。数据库中的图像是反模式。 JSON中的图像可以正常工作,但它们应该以base64字符串形式编码在JSON中。即使如此,它们也会降低JSON的可读性,并且可能会隐藏类似Postman的工具。数据URL加载速度比常规URL慢得多。即使有图像在数据库中,如果您控制您的API,您可以通过创建仅返回字节数组的图像API,并使用application / jpeg MIME类型获得很多收益。


请查看我的帖子。它已经更新了。我分享了图像的JSON响应长什么样子。 - CoderPJ

3

您可以通过Base64格式加载图像数据,像这样:

<img src="">

针对您的问题,
export default {
    data(){
        return{
            info: {
                name: '',
                image: '',

            },
            errors: []
        }
    },

  created: function(){
        this.getInfo();
  },

  methods: {
        getInfo: function(){
              this.info.name = response.data.results[0].name;
              this.info.image = 'data:image/jpeg;base64,' + btoa(response.data.results[0].image.data);
        }
  }
}

在模板中,

<template>
    <div class="ui items">
        <div class="item">
            <div class="ui small image">
                <img :src="info.image">
            </div>
        </div>
    </div>
</template>

这确实是一个解决方案,但效率不高。这是一项繁琐的任务。未来需要从数据库加载多个图像。有没有内置函数可以使用?谢谢! - CoderPJ
不确定是否有更好的方法。但为了更清晰,可以在这里查看。 - Anwarus
不确定是否有更好的方法,但您也可以检查这个链接:https://stackoverflow.com/questions/41859827/binding-img-src - Casper
@Anwarus 谢谢。请检查我的帖子。已经更新了。我分享了图片的JSON响应长什么样子。 - CoderPJ
@CasperSL 请检查我的帖子。已经更新了。我分享了图片的JSON响应长什么样子。 - CoderPJ
请查看以下链接:https://dev59.com/mmUp5IYBdhLWcg3w8bNB - Casper

-1
<img :src="require(`../../assets/images/products/${product.img}`)" />

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接