Скачать файл IE, JS - PullRequest
       33

Скачать файл IE, JS

0 голосов
/ 09 октября 2019

У меня есть этот обработчик событий, который выполняет загрузку, и он прекрасно работает во всех браузерах, кроме IE, поэтому я обработал его с помощью msSaveBlob, и он загружает файл, но когда я его открываю, он говорит, что формат не очень хороший, поэтому мойЯ предполагаю, что я не использую действительные данные в BLOB-объекте.

$(document).on('click', '.register-file-uploader-download-file', function () {
        let $fileResultsItem = $(this).closest('.form-fields__file-results-item');
        const fileName = $fileResultsItem.find('.multiple-files-upload-item').data('filename');
        const fileUrl = $fileResultsItem.find('.multiple-files-upload-item').val();
        if (fileUrl.length > 0) {
            var xhr = new XMLHttpRequest();
            xhr.onreadystatechange = function () {
                if (this.readyState === 4 && this.status === 200) {
                    var url = window.URL || window.webkitURL;
                    let blobFileUrl = url.createObjectURL(this.response);
                    if (window.navigator && navigator.msSaveBlob) { // For IE
                        const blobObj = new Blob([this.response], { type: 'application/octet-stream' });
                        return navigator.msSaveBlob(blobObj, fileName);
                    }
                    const a = document.createElement('a');
                    a.style.display = 'none';
                    a.href = blobFileUrl;
                    a.download = `${fileName}`;
                    document.body.appendChild(a);
                    a.click();
                    url.revokeObjectURL(blobFileUrl);
                }
            };
            xhr.open('GET', fileUrl);
            xhr.responseType = 'blob';
            xhr.send();
        }
    });

1 Ответ

0 голосов
/ 10 октября 2019

Я нашел ошибку. Код работает нормально, проблема в том, что я пытался загрузить изображение, которое было загружено на сервер стадии, и когда я загрузил и загрузил его, и он работает

...