FileSaver. js не сохраняется внутри модального - PullRequest
0 голосов
/ 25 февраля 2020

У меня есть страница со списком элементов, и когда я нажимаю кнопку, она открывает модал Boostrap. Внутри этого модального я извлекаю документы из этого элемента, и они представляют собой ссылки на файлы для скачивания. Если я впервые открываю модальное окно и щелкаю по любому элементу, который он успешно загружает, но когда я закрываю модальное и снова открываю тот же или другой элемент, когда я нажимаю ссылки файлов, они ничего не делают.

При отладке я вижу, что проблема в том, что функция «Сохранить как» не имеет значения.

Код jQuery, который я вызываю на странице, следующий:

jQuery("#modalPrint").on("click", ".contenidorDocsUsuari > ul > li > a", function(e) {
    e.preventDefault();

    strFileName = jQuery(this).parent().data("filename");
    strB64File = jQuery(this).parent().data("b64");
    var blob = base64toBlob(strB64File , "data:application/octet-stream;charset=utf-8;base64");
    saveAs(blob, strFileName );
});

Функция base64toBlob:

function base64toBlob(base64Data, contentType) {
contentType = contentType || '';
var sliceSize = 1024;
var byteCharacters = atob(base64Data);
var bytesLength = byteCharacters.length;
var slicesCount = Math.ceil(bytesLength / sliceSize);
var byteArrays = new Array(slicesCount);

for (var sliceIndex = 0; sliceIndex < slicesCount; ++sliceIndex) {
    var begin = sliceIndex * sliceSize;
    var end = Math.min(begin + sliceSize, bytesLength);

    var bytes = new Array(end - begin);
    for (var offset = begin, i = 0; offset < end; ++i, ++offset) {
        bytes[i] = byteCharacters[offset].charCodeAt(0);
    }
    byteArrays[sliceIndex] = new Uint8Array(bytes);
}
return new Blob(byteArrays, { type: contentType });
}
...