微信小程序 base64格式圖片的展示保存及pdf打開

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

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

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

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

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

如果后端返回的是圖片

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ù)需要寫成: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打開預(yù)覽

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

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('打開PDF成功');
              }, fail(err) {
                console.log(err)
              }
            })
          }
        })

4、說明:

  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)系作者
  • 序言:七十年代末湿颅,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子粥诫,更是在濱河造成了極大的恐慌油航,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件怀浆,死亡現(xiàn)場(chǎng)離奇詭異谊囚,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)揉稚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門秒啦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人搀玖,你說我怎么就攤上這事余境。” “怎么了?”我有些...
    開封第一講書人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵芳来,是天一觀的道長(zhǎng)含末。 經(jīng)常有香客問我,道長(zhǎng)即舌,這世上最難降的妖魔是什么佣盒? 我笑而不...
    開封第一講書人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮顽聂,結(jié)果婚禮上肥惭,老公的妹妹穿的比我還像新娘。我一直安慰自己紊搪,他們只是感情好蜜葱,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著耀石,像睡著了一般牵囤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上滞伟,一...
    開封第一講書人閱讀 51,541評(píng)論 1 305
  • 那天揭鳞,我揣著相機(jī)與錄音,去河邊找鬼梆奈。 笑死野崇,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的鉴裹。 我是一名探鬼主播舞骆,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼钥弯,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼径荔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起脆霎,我...
    開封第一講書人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤总处,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后睛蛛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鹦马,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年忆肾,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了荸频。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡客冈,死狀恐怖旭从,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤和悦,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布退疫,位于F島的核電站,受9級(jí)特大地震影響鸽素,放射性物質(zhì)發(fā)生泄漏褒繁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一馍忽、第九天 我趴在偏房一處隱蔽的房頂上張望棒坏。 院中可真熱鬧,春花似錦遭笋、人聲如沸俊抵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)徽诲。三九已至,卻和暖如春吵血,著一層夾襖步出監(jiān)牢的瞬間谎替,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工蹋辅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留钱贯,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓侦另,卻偏偏與公主長(zhǎng)得像秩命,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子褒傅,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355