91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在vue中利用base64對圖片進行下載

發布時間:2020-12-19 16:53:01 來源:億速云 閱讀:366 作者:Leah 欄目:開發技術

怎么在vue中利用base64對圖片進行下載?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

1. 使用場景

當我們處理圖片下載功能的時候,如果本地的圖片,那么是可以通過canvas獲得圖片的base64的,方法如下。但是如果圖片的url存在跨域問題的話,下面的方法將行不通,這時候我們可以另辟蹊徑,將后臺的同學,將圖片以base64的形式進行返回。

function getBase64(url){
  //通過構造函數來創建的 img 實例,在賦予 src 值后就會立刻下載圖片,相比 createElement() 創建 <img> 省去了 append(),也就避免了文檔冗余和污染
  var Img = new Image(),
    dataURL='';
  Img.src=url;
  Img.onload=function(){ //要先確保圖片完整獲取到,這是個異步事件
    var canvas = document.createElement("canvas"), //創建canvas元素
      width=Img.width, //確保canvas的尺寸和圖片一樣
      height=Img.height;
    canvas.width=width;
    canvas.height=height;
    canvas.getContext("2d").drawImage(Img,0,0,width,height); //將圖片繪制到canvas中
    dataURL=canvas.toDataURL('image/jpeg'); //轉換圖片為dataURL
  };
}

2. 處理base64,進行下載

處理base64的時候有兩點要注意,一個是對ie瀏覽器的處理,一個是對火狐瀏覽器的處理

2-1. 我們首先直接處理base64(基于vue)

1.由于后臺返回的是純base64,如果要完成圖片的下載功能,必須加上一個前綴

<template>
 <a
  :href="prefixBase64 + qrBase64" rel="external nofollow" rel="external nofollow" 
  download="qrcode.png"
  class="qrcode"
 >
  <img src="static/img/load.png">
 </a>
</template>
 
<script>
 ...
 data () {
  return {
   qrBase64: '', // 二維碼對應的base64(在方法里面進行獲取)
   prefixBase64: 'data:image/png;base64,', // base64前綴
  }
 }
 ...
</script>

2.采用這種方式可以很好的支持chrome、Firefox、opera、Safari,但是不支持ie,所以我們下面單獨處理ie瀏覽器

2-2. 處理ie瀏覽器

1.修改代碼如下

<template>
 <a
  @click.stop.prevent="handleDownloadQrIMg"
  class="qrcode"
 >
  <img src="static/img/load.png">
 </a>
</template>
<script>
export default {
 methods: {
  // 點擊下載圖片
  handleDownloadQrIMg() {
   // 這里是獲取到的圖片base64編碼,這里只是個例子哈,要自行編碼圖片替換這里才能測試看到效果
   const imgUrl = this.prefixBase64 + this.qrBase64;
   // 如果瀏覽器支持msSaveOrOpenBlob方法(也就是使用IE瀏覽器的時候),那么調用該方法去下載圖片
   if (window.navigator.msSaveOrOpenBlob) {
    let bstr = atob(imgUrl.split(",")[1]);
    let n = bstr.length;
    let u8arr = new Uint8Array(n);
    while (n--) {
     u8arr[n] = bstr.charCodeAt(n);
    }
    let blob = new Blob([u8arr]);
    window.navigator.msSaveOrOpenBlob(blob, "chart-download" + "." + "png");
   } else {
    // 這里就按照chrome等新版瀏覽器來處理
    let a = document.createElement("a");
    a.href = imgUrl;
    a.setAttribute("download", "chart-download");
    a.click();
   }
  }
 }
};
</script>

2.ok,ie的問題解決了,但是火狐的又不行了

2-3. 兼容方法

1.結合上面兩種檢測方法,我們只要可以判斷瀏覽器是火狐,然后單獨處理就可以實現我們的兼容性了

<template>
 <div>
  <a
   v-if="!isFirefox"
   @click.stop.prevent="handleDownloadQrIMg"
   class="qrcode"
  >
   <img src="static/img/load.png">
  </a>
  <a
   v-if="isFirefox"
   :href="prefixBase64 + qrBase64" rel="external nofollow" rel="external nofollow" 
   download="qrcode.png"
   class="qrcode"
  >
   <img src="static/img/load.png">
  </a>
 
 </div>
 
</template>
 
<script>
export default {
 data() {
  return {
   qrBase64: "", // 二維碼對應的base64(在方法里面進行獲取)
   prefixBase64: "data:image/png;base64,", // base64前綴
   isFirefox: false
  };
 },
 mounted() {
  // 判斷瀏覽器是否是火狐
  if (navigator.userAgent.indexOf("Firefox") > 0) {
   this.isFirefox = true;
  }
 },
 methods: {
  // 點擊下載圖片
  handleDownloadQrIMg() {
   // 這里是獲取到的圖片base64編碼,這里只是個例子哈,要自行編碼圖片替換這里才能測試看到效果
   const imgUrl = this.prefixBase64 + this.qrBase64;
   // 如果瀏覽器支持msSaveOrOpenBlob方法(也就是使用IE瀏覽器的時候),那么調用該方法去下載圖片
   if (window.navigator.msSaveOrOpenBlob) {
    let bstr = atob(imgUrl.split(",")[1]);
    let n = bstr.length;
    let u8arr = new Uint8Array(n);
    while (n--) {
     u8arr[n] = bstr.charCodeAt(n);
    }
    let blob = new Blob([u8arr]);
    window.navigator.msSaveOrOpenBlob(blob, "chart-download" + "." + "png");
   } else {
    // 這里就按照chrome等新版瀏覽器來處理
    let a = document.createElement("a");
    a.href = imgUrl;
    a.setAttribute("download", "chart-download");
    a.click();
   }
  }
 }
};
</script>

關于怎么在vue中利用base64對圖片進行下載問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

寿宁县| 南木林县| 长治市| 通州区| 扶沟县| 无棣县| 三穗县| 益阳市| 嘉荫县| 景宁| 贞丰县| 玉环县| 盈江县| 连城县| 区。| 阿拉善右旗| 馆陶县| 菏泽市| 松桃| 扬中市| 岑溪市| 大厂| 定远县| 吉首市| 海南省| 寻乌县| 安化县| 余江县| 山阳县| 会昌县| 电白县| 泊头市| 札达县| 青冈县| 华宁县| 云和县| 仁寿县| 建湖县| 萨迦县| 丰镇市| 芦溪县|