フロントエンドを使用して Base64 イメージをダウンロードする方法 (コード)

不言
リリース: 2018-09-14 15:59:26
オリジナル
5280 人が閲覧しました

この記事の内容は、フロントエンドを使用して Base64 イメージのダウンロード (コード) を実装する方法に関するものです。必要な方は参考にしていただければ幸いです。

背景

プロジェクト開発プロセス中、特にチャートを含むアプリケーションの場合、画像をエクスポートする必要がよくあります。通常、チャートのダウンロードとエクスポートが必要です。
Chrome などの新しいブラウザで Base64 イメージをダウンロードするのは比較的簡単です。

  1. タグを作成します

  2. The href を配置しますタグの属性には、画像の Base64 エンコーディングが割り当てられます。

  3. a タグの download 属性を、ダウンロードされるファイルの名前として指定します。

  4. タグをトリガーします Click イベント

ただし、この一連のロジックは IE では機能せず、この方法で記述すると直接エラーが報告されます。
したがって、IE は個別に処理する必要があります。この種のファイルを処理する場合、IE は別のメソッドを提供します: window.navigator.msSaveOrOpenBlob(blob, download_filename)。このメソッドを呼び出すと、IE のダウンロードがより便利になります。 。 の。具体的な方法は次のとおりです。

// 截取base64的数据内容(去掉前面的描述信息,类似这样的一段:data:image/png;base64,)并解码为2进制数据
var bstr = atob(imgUrl.split(',')[1]) 
// 获取解码后的二进制数据的长度,用于后面创建二进制数据容器
var n = bstr.length 
// 创建一个Uint8Array类型的数组以存放二进制数据
var u8arr = new Uint8Array(n) 
// 将二进制数据存入Uint8Array类型的数组中
while (n--) {
  u8arr[n] = bstr.charCodeAt(n) 
}
// 创建blob对象
var blob = new Blob([u8arr])
// 调用浏览器的方法,调起IE的下载流程
window.navigator.msSaveOrOpenBlob(blob, 'chart-download' + '.' + 'png')
ログイン後にコピー

全体的な実装コード

  // 这里是获取到的图片base64编码,这里只是个例子哈,要自行编码图片替换这里才能测试看到效果
  const imgUrl = 'data:image/png;base64,...'
  // 如果浏览器支持msSaveOrOpenBlob方法(也就是使用IE浏览器的时候),那么调用该方法去下载图片
  if (window.navigator.msSaveOrOpenBlob) {
    var bstr = atob(imgUrl.split(',')[1])
    var n = bstr.length
    var u8arr = new Uint8Array(n)
    while (n--) {
      u8arr[n] = bstr.charCodeAt(n)
    }
    var blob = new Blob([u8arr])
    window.navigator.msSaveOrOpenBlob(blob, 'chart-download' + '.' + 'png')
  } else {
    // 这里就按照chrome等新版浏览器来处理
    const a = document.createElement('a')
    a.href = imgUrl
    a.setAttribute('download', 'chart-download')
    a.click()
  }
ログイン後にコピー

関連する推奨事項:

php Base64ベースのデコードされたイメージと暗号化されたイメージの復元例

以上がフロントエンドを使用して Base64 イメージをダウンロードする方法 (コード)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート