微信小程序 base64格式圖片的展示保存及pdf打開(kāi)

1、使用image標(biāo)簽

src屬性添加data:image/png;base64
(注意:若imgData返回?cái)?shù)據(jù)中含有data:image/png;base64,時(shí),src直接寫(xiě)src="{{imgData}}"即可)

<image src="data:image/png;base64,{{imgData}}"></image>

顯示不出來(lái),有一種原因是因?yàn)榉祷氐腷ase64的數(shù)據(jù)中存在回車(chē)換行,需要回車(chē)換行替換為''即可。

var imgData = imgData .replace(/[\r\n]/g, '') // 將回車(chē)換行換為空字符''

如果后端返回的是圖片

wx.request({
      url: url, //獲取圖片的URL
      method:"get",,
      responseType: 'arraybuffer',   
      success (res) {
        let url ='data:image/png;base64,'+wx.arrayBufferToBase64(res.data)
        that.setData({
          codeUrl : url,     //設(shè)置data里面的圖片url
        })
      },
      fail(res){

      }
    })

wxml里面代碼如下:

<view>
    <image src='{{codeUrl}}'></image>
  </view>

2、如何保存

(注意:若imgData返回?cái)?shù)據(jù)中含有data:image/png;base64,時(shí),data參數(shù)需要寫(xiě)成:imgSrc.slice(22),意思為:這里是把 data:image/png;base64, 這一段去除)

var imgSrc =  this.data.imgData; //base64編碼
    var fs = wx.getFileSystemManager();
    var number = Math.random();
    fs.writeFile({
      filePath: wx.env.USER_DATA_PATH + '/pic' + number + '.png',
      data: imgSrc,
      encoding: 'base64',
      success: res => {
        wx.saveImageToPhotosAlbum({
          filePath: wx.env.USER_DATA_PATH + '/pic' + number + '.png',
          success: function (res) {
            wx.showToast({
              title: '保存成功',
            })
          },
          fail: function (err) {
            console.log(err)
          }
        })
        console.log(res)
      }, fail: err => {
        console.log(err)
      }
    })

3、PDf打開(kāi)預(yù)覽

用wx.base64ToArrayBuffer()將 Base64 字符串轉(zhuǎn)成 ArrayBuffer 對(duì)象并去空格,再寫(xiě)入文件,最后打開(kāi)。

var fs = wx.getFileSystemManager();
fs.writeFile({
          filePath: wx.env.USER_DATA_PATH + "/" + fileName + '.pdf',
          data: wx.base64ToArrayBuffer(pdfBase64.replace(/[\r\n]/g, "")),
          success:res =>{
            console.log(res)
            wx.openDocument({
              filePath: wx.env.USER_DATA_PATH + "/" + fileName+'.pdf',
              success: function (res) {
                console.log('打開(kāi)PDF成功');
              }, fail(err) {
                console.log(err)
              }
            })
          }
        })

4、說(shuō)明:

  1. wx.getFileSystemManager() 是獲取文件管理器對(duì)象
  2. wx.env.USER_DATA_PATH + '/pic' + number + '.png'表示生成一個(gè)臨時(shí)文件名
    3、pdfBase64是后臺(tái)接口返回的base64的數(shù)據(jù)流
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容