亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue如何獲取圖片流數(shù)據(jù)并展示

 更新時間:2023年09月26日 10:55:35   作者:程序員的脫發(fā)之路  
這篇文章主要介紹了vue如何獲取圖片流數(shù)據(jù)并展示問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

一、問題描述

該場景適用于所有后端傳遞圖片流數(shù)據(jù)給前端的情形

比如說當(dāng)我們在做登錄驗證是,我們可能需要從后端獲取驗證碼,這是后端傳遞給你的可能是一個圖片數(shù)據(jù)而不是驗證碼數(shù)字。

接口回參:

打印一下:

二、數(shù)據(jù)獲取

如果我們在請求接口獲取數(shù)據(jù)時不指定返回數(shù)據(jù)類型的話,我們獲取到的可能就是一堆亂碼數(shù)據(jù)。

因此我們在axios接口請求里面指定responseType為blob

再打印一下:

這就獲得一個封裝好的blob類型數(shù)據(jù)了

三、數(shù)據(jù)展示

獲取到數(shù)據(jù)之后要用img標簽進行展示,img標簽的src需要直接指向blob數(shù)據(jù)的話是沒有用的,所以我們要創(chuàng)建一個url來指向的的blob數(shù)據(jù),然后將url賦給img的src屬性。

1.window.URL.createObjectURL()

(1)URL

URL接口用于解析,構(gòu)造,規(guī)范化和編碼 URLs。

它通過提供允許您輕松閱讀和修改URL組件的屬性來工作。

通常,通過在調(diào)用URL的構(gòu)造函數(shù)時將URL指定為字符串或提供相對URL和基本URL來創(chuàng)建新的URL對象。

然后,您可以輕松讀取URL的已解析組成部分或?qū)RL進行更改。

如果瀏覽器尚不支持URL()構(gòu)造函數(shù),則可以使用Window中的Window.URL屬性。

確保檢查您的任何目標瀏覽器是否要求對此添加前綴。

(2)createObjectURL

createObjectURL返回一個DOMString包含一個唯一的blob鏈接(該鏈接協(xié)議為以blob:,后跟唯一標識瀏覽器中的對象的掩碼)。

2.封裝blob數(shù)據(jù)

3.將url的值賦給img標簽的src屬性

四、最終結(jié)果

五、另一種方式(FileReader)

我們使用FileReader API也可以實現(xiàn),不過我們是將file類型轉(zhuǎn)換為base64編碼,這樣img標簽就可以之間展示。

1.FileReader

FileReader 對象允許Web應(yīng)用程序異步讀取存儲在用戶計算機上的文件(或原始數(shù)據(jù)緩沖區(qū))的內(nèi)容,使用 File 或 Blob 對象指定要讀取的文件或數(shù)據(jù)。

其中File對象可以是來自用戶在一個元素上選擇文件后返回的FileList對象,也可以來自拖放操作生成的 DataTransfer對象,還可以是來自在一個HTMLCanvasElement上執(zhí)行mozGetAsFile()方法后返回結(jié)果。

詳細可見MDN的:FileReader

所以當(dāng)后端傳遞一個file類型或者前端用戶上傳一個文件時,我們可以使用FileReader來進行處理

2.具體實現(xiàn)

        let reader = new FileReader(); // 創(chuàng)建FileReader()實例
        reader.onload = function (evt) { // 當(dāng)文件讀取完成時會執(zhí)行onload事件
            //替換img標簽的url
            $("#showImg1").attr("src", evt.target.result);
            console.log(evt.target.result); // evt.target.result就是圖片文件的base64編碼
        }
        reader.readAsDataURL(imgFile); // 讀取imgFile文件

3.簡單介紹

簡單記錄一下FileRender的具體事件以及方法:

(1)事件

  • FileReader.onabort :處理abort (en-US)事件。該事件在讀取操作被中斷時觸發(fā)。
  • FileReader.onerror :處理error (en-US)事件。該事件在讀取操作發(fā)生錯誤時觸發(fā)。
  • FileReader.onload :處理load (en-US)事件。該事件在讀取操作完成時觸發(fā)。

(2)方法

  • FileReader.abort() :中止讀取操作。在返回時,readyState屬性為DONE。
  • FileReader.readAsArrayBuffer() :開始讀取指定的 Blob中的內(nèi)容, 一旦完成, result 屬性中保存的將是被讀取文件的 ArrayBuffer 數(shù)據(jù)對象.
  • FileReader.readAsBinaryString() :開始讀取指定的Blob中的內(nèi)容。一旦完成,result屬性中將包含所讀取文件的原始二進制數(shù)據(jù)。
  • FileReader.readAsDataURL() :開始讀取指定的Blob中的內(nèi)容。一旦完成,result屬性中將包含一個data: URL格式的Base64字符串以表示所讀取文件的內(nèi)容。
  • FileReader.readAsText() :開始讀取指定的Blob中的內(nèi)容。一旦完成,result屬性中將包含一個字符串以表示所讀取的文件內(nèi)容。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue3 diff算法之雙端diff算法詳解

    Vue3 diff算法之雙端diff算法詳解

    雙端Diff在可以解決更多簡單Diff算法處理不了的場景,且比簡單Diff算法性能更好。本文將通過示例為大家詳細講講雙端diff算法的實現(xiàn)與使用,需要的可以參考一下
    2022-09-09
  • Vue 列表上下過渡效果的實例代碼

    Vue 列表上下過渡效果的實例代碼

    最近有個需求,一個列表上下移動要有簡單過渡效果。本文通過實例代碼給大家介紹Vue 列表上下過渡效果,需要的朋友可以參考下
    2019-06-06
  • Vue中關(guān)于異步請求數(shù)據(jù)未更新的解決

    Vue中關(guān)于異步請求數(shù)據(jù)未更新的解決

    本文將探討Vue中異步請求數(shù)據(jù)未更新的常見原因,并提供解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2025-03-03
  • vue webpack打包后圖片路徑錯誤的完美解決方法

    vue webpack打包后圖片路徑錯誤的完美解決方法

    這篇文章主要介紹了vue webpack打包后圖片路徑錯誤的解決方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-12-12
  • 分享vue里swiper的一些坑

    分享vue里swiper的一些坑

    這篇文章主要介紹了vue里swiper的一些坑及swiper在vue中的使用,本文分步驟給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-08-08
  • Vue項目如何配置git忽略文件

    Vue項目如何配置git忽略文件

    這篇文章主要介紹了Vue項目如何配置git忽略文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue中設(shè)置背景圖片和透明度的簡單方法

    Vue中設(shè)置背景圖片和透明度的簡單方法

    在做項目的時候常需要設(shè)置背景圖片和透明度,下面這篇文章主要給大家介紹了關(guān)于Vue中設(shè)置背景圖片和透明度的簡單方法,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-01-01
  • vue使用element-ui的el-date-picker設(shè)置樣式無效的解決

    vue使用element-ui的el-date-picker設(shè)置樣式無效的解決

    本文主要介紹了vue使用element-ui的el-date-picker設(shè)置樣式無效的解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • VUE響應(yīng)式原理的實現(xiàn)詳解

    VUE響應(yīng)式原理的實現(xiàn)詳解

    這篇文章主要為大家詳細介紹了VUE響應(yīng)式原理的實現(xiàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • vue2.0實現(xiàn)移動端的輸入框?qū)崟r檢索更新列表功能

    vue2.0實現(xiàn)移動端的輸入框?qū)崟r檢索更新列表功能

    最近小編在做vue2.0的項目,遇到移動端實時檢索搜索更新列表的效果,下面腳本之家小編給大家?guī)砹藇ue2.0 移動端的輸入框?qū)崟r檢索更新列表功能的實例代碼,感興趣的朋友參考下吧
    2018-05-05

最新評論