簡體   English   中英

如何使用Vuejs在html中顯示mysql blob圖像?

[英]How to display mysql blob image in html using Vuejs?

我有一個這樣的 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>

我的圖像在 MySQL 數據庫中存儲為 blob。 當我運行我的應用程序時,圖像在 UI 上顯示為二進制數據。 物體看起來像這樣,

圖像的 JSON 響應

這里有人可以幫我顯示圖像嗎? 非常感謝!

你想要的是一個數據 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 中的圖像可以工作,但它們應該在 JSON 中編碼為 base64 字符串。 即便如此,它們也會降低 JSON 的可讀性,並且可以掩埋 Postman 之類的工具。 數據 url 的加載速度比常規 url得多。 即使使用數據庫中的圖像,如果您控制您的 api,您也可以通過使用 application/jpeg mime 類型制作僅返回字節數組的圖像 api 來獲得很多收益。

您可以使用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>
<img :src="require(`../../assets/images/products/${product.img}`)" />

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM