一般ダウンロード&&Vueファイル画像ダウンロード処理
2903 ワード
一般的なダウンロードは、aラベルにリンクアドレスを付け、ラベルにdownload属性を付ける.アドレスがバックエンドで提供する場合:aラベルを作成することによって、すぐにa便箋にダウンロードリンク、ファイル名と属性を添付し、最後にクリック効果を作成し、最後に生成したaラベルを明確にすることができる.更に、画像アドレスの提供:Base 64にcanvasを加えることで、画像のダウンロードを処理することができる.次に、関数HTMLとファイルダウンロードの処理方法について説明します.
HTMLとファイルのダウンロード
ファイルのダウンロードとバックエンドテーブルのエクスポート
パラメータ:
HTML 5 Blobによるテキスト情報ファイルのダウンロード
Base 64による任意のファイルダウンロード
終わりの言葉
Chromeブラウザでは、アナログクリックで作成したa要素は、appendをページに入れなくてもダウンロードをトリガーできますが、Firefoxブラウザではダメなので、上のfunDownload()メソッドにはappendChildとremoveChildの処理があり、Firefoxブラウザを兼ねるためです.
一般ダウンロード&&Vueファイル画像ダウンロード処理
HTMLとファイルのダウンロード
ダウンロード
ファイルのダウンロードとバックエンドテーブルのエクスポート
export function downloadFile(url, filename) {
//
let link = document.createElement('a');
link.href = url;
link.download = filename;
link.target = '_blank';
link.style.display = 'none';
document.body.appendChild(link);
//
link.click();
//
document.body.removeChild(link);
link = null;
}
パラメータ:
export function generateQS(baseurl, paramObj) {
let returnUrl = baseurl + '?'
for (const key in paramObj) {
// Object.hasOwnProperty(prop)
// boolean
if (paramObj.hasOwnProperty(key)) {
const element = paramObj[key];
returnUrl += key + '=' + element + '&';
}
}
return returnUrl;
}
HTML 5 Blobによるテキスト情報ファイルのダウンロード
const funDownload = function (content, filename) {
//
let eleLink = document.createElement('a');
eleLink.download = filename;
eleLink.style.display = 'none';
// blob
let blob = new Blob([content]);
eleLink.href = URL.createObjectURL(blob);
//
document.body.appendChild(eleLink);
eleLink.click();
//
document.body.removeChild(eleLink);
};
Base 64による任意のファイルダウンロード
let funDownload = function (domImg, filename) {
//
let eleLink = document.createElement('a');
eleLink.download = filename;
eleLink.style.display = 'none';
// base64
let canvas = document.createElement('canvas');
let context = canvas.getContext('2d');
let width = domImg.naturalWidth;
let height = domImg.naturalHeight;
context.drawImage(domImg, 0, 0);
// PNG , canvas.toDataURL('image/png')
eleLink.href = canvas.toDataURL('image/jpeg');
//
document.body.appendChild(eleLink);
eleLink.click();
//
document.body.removeChild(eleLink);
};
終わりの言葉
Chromeブラウザでは、アナログクリックで作成したa要素は、appendをページに入れなくてもダウンロードをトリガーできますが、Firefoxブラウザではダメなので、上のfunDownload()メソッドにはappendChildとremoveChildの処理があり、Firefoxブラウザを兼ねるためです.
一般ダウンロード&&Vueファイル画像ダウンロード処理