使用JavaScript將圖片保存至本地

在最近的開發當中,咱們須要爲img標籤以及canvas動態繪製的圖像提供下載功能,下面是通過探索後咱們得出的結果。

1、Canvas 版本

// 下載Canvas元素的圖片
function downloadCanvasIamge(selector, name) {
    // 經過選擇器獲取canvas元素
    var canvas = document.querySelector(selector)
    // 使用toDataURL方法將圖像轉換被base64編碼的URL字符串
    var url = canvas.toDataURL('image/png')
    // 生成一個a元素
    var a = document.createElement('a')
    // 建立一個單擊事件
    var event = new MouseEvent('click')
    
    // 將a的download屬性設置爲咱們想要下載的圖片名稱,若name不存在則使用‘下載圖片名稱’做爲默認名稱
    a.download = name || '下載圖片名稱'
    // 將生成的URL設置爲a.href屬性
    a.href = url
    
    // 觸發a的單擊事件
    a.dispatchEvent(event)
}

// 調用方式
// 參數一: 選擇器,表明canvas
// 參數二: 圖片名稱,可選
downloadCanvasIamge('canvas', '圖片名稱')

2、img 標籤版本

// 下載
function downloadIamge(selector, name) {
    // 經過選擇器獲取img元素
    var img = document.querySelector(selector)
    // 將圖片的src屬性做爲URL地址
    var url = img.src
    var a = document.createElement('a')
    var event = new MouseEvent('click')
    
    a.download = name || '下載圖片名稱'
    a.href = url
    
    a.dispatchEvent(event)
}

// 調用方式
// 參數一: 選擇器,表明img標籤
// 參數二: 圖片名稱,可選
downloadIamge('canvas', '圖片名稱')

改進版

因爲跨域會致使a標籤在部分瀏覽器中會直接打開新標籤頁,因此改進以下

function downloadIamge(selector, name) {
    var image = new Image()
    // 解決跨域 Canvas 污染問題
    image.setAttribute('crossOrigin', 'anonymous')
    image.onload = function () {
        var canvas = document.createElement('canvas')
        canvas.width = image.width
        canvas.height = image.height

        var context = canvas.getContext('2d')
        context.drawImage(image, 0, 0, image.width, image.height)
        var url = canvas.toDataURL('image/png')

        // 生成一個a元素
        var a = document.createElement('a')
        // 建立一個單擊事件
        var event = new MouseEvent('click')

        // 將a的download屬性設置爲咱們想要下載的圖片名稱,若name不存在則使用‘下載圖片名稱’做爲默認名稱
        a.download = name || '下載圖片名稱'
        // 將生成的URL設置爲a.href屬性
        a.href = url

        // 觸發a的單擊事件
        a.dispatchEvent(event)
    }

    image.src = document.querySelector(selector).src
}

// 調用方式
// 參數一: 選擇器,表明img標籤
// 參數二: 圖片名稱,可選
downloadIamge('canvas', '圖片名稱')

3、總結

咱們主要使用的是a標籤的download屬性, 下面爲MDN給出的說明:

此屬性指示瀏覽器下載URL而不是導航到URL,所以將提示用戶將其保存爲本地文件。
若是屬性有一個值,它將在保存提示中用做預先填寫的文件名 (用戶仍然能夠根據須要更改文件名)。對容許的值沒有限制,可是/和\被轉換爲下劃線。大多數文件系統限制文件名中的一些標點符號,瀏覽器會相應地調整建議的名稱。canvas

須要注意的地方:

  • 此屬性僅適用於同源 URLs。跨域

  • 可使用 blob: URLs 和 data: URLs 以方便用戶下載 JavaScript 方式生成的內容(例如使用在線繪圖的Web應用建立的照片)。瀏覽器

  • 若是HTTP頭的Content-Disposition:存在,而且賦予了一個和這個屬性不一樣的文件名,HTTP頭優先於此屬性。app

  • 若是這個屬性存在 Content-Disposition 被設置爲 inline,火狐優先 Content-Disposition,像以前文件名​​的狀況下,而Chrome則優先 download 屬性。google

支持:google,IE9以上版本。

相關文章
相關標籤/搜索