国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > HTML5 > 正文

解決H5的a標簽的download屬性下載service上的文件出現(xiàn)跨域問題

2024-09-05 07:19:32
字體:
來源:轉載
供稿:網友

1.通過點擊下載多媒體文件(圖片/視頻/文件等)

最簡單的方式:

<a href='url' download="filename.ext">下載文件</a>

如果url指向同源資源,是正常的。

如果url指向第三方資源,download會失效,表現(xiàn)和不使用download時一致——瀏覽器能打開的文件,瀏覽器會直接打開,不能打開的文件,會直接下載。瀏覽器打開的文件,可以手動下載。

解決方案一:將文件打包為.zip/.rar等瀏覽器不能打開的文件下載。

解決方案二:通過后端轉發(fā),后端請求第三方資源,返回給前端,前端使用file-saver等工具保存文件。

如果url指向的第三方資源配置了CORS,download屬性無效,但可以獲取文件下載到本地,無法修改修改文件名。

2.解決方法

1. 借助HTML5 Blob實現(xiàn)文本信息文件下載

const downloadRes = async (url, name) => {    let response = await fetch(url)    // 內容轉變成blob地址    let blob = await response.blob()    // 創(chuàng)建隱藏的可下載鏈接    let objectUrl = window.URL.createObjectURL(blob)    let a = document.createElement('a')    //地址    a.href = objectUrl    //修改文件名    a.download = name    // 觸發(fā)點擊    document.body.appendChild(a)    a.click()    //移除    setTimeout(() => document.body.removeChild(a), 1000)}

2.圖片格式

如果我們想下載一張圖片,可以把這張圖片轉換成base64格式,然后下載。

```export const downloadImg = async (url, name) => {    var canvas = document.createElement('canvas'),        ctx = canvas.getContext('2d'),        img = new Image();    img.crossOrigin = 'Anonymous';    img.onload = function() {        canvas.height = img.height;        canvas.width = img.width;        ctx.drawImage(img, 0, 0);        var dataURL = canvas.toDataURL('image/png');        let a = document.createElement('a');        a.href = dataURL;        a.download = name;        document.body.appendChild(a);        a.click();        setTimeout(() => {            document.body.removeChild(a);            canvas = null;        }, 1000);    };    img.src = url;};```

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 蚌埠市| 安新县| 瓮安县| 潞西市| 德令哈市| 新巴尔虎右旗| 台湾省| 枝江市| 玉田县| 上虞市| 沾化县| 延川县| 清水县| 含山县| 郑州市| 梨树县| 青龙| 蒙山县| 阳信县| 托里县| 白河县| 星子县| 安塞县| 鲁山县| 永新县| 新巴尔虎左旗| 五大连池市| 信阳市| 长丰县| 中江县| 嘉荫县| 庄浪县| 晋江市| 巍山| 锦屏县| 嵊泗县| 博野县| 通州区| 揭西县| 堆龙德庆县| 沙洋县|