16

ユーザーがダウンロードできるようにテキスト ファイルに出力するテキストを含むテキスト領域があります。

ユーザーが保存ボタンをクリックしたときにこの関数を使用して取得しています

function saveTextAsFile()
{
    var textToWrite = document.getElementById("inputText").value;
    var textFileAsBlob = new Blob([textToWrite], {type:'text/plain'});
    alert(textFileAsBlob);
    var fileNameToSaveAs = document.getElementById("inputFileNameToSaveAs").value;

    var downloadLink = document.createElement("a");
    downloadLink.download = fileNameToSaveAs;
    downloadLink.innerHTML = "Download File";
    if (window.webkitURL != null)
    {
        // Chrome allows the link to be clicked
        // without actually adding it to the DOM.
        downloadLink.href = window.webkitURL.createObjectURL(textFileAsBlob);
    }
    else
    {
        // Firefox requires the link to be added to the DOM
        // before it can be clicked.
        downloadLink.href = window.URL.createObjectURL(textFileAsBlob);
        downloadLink.onclick = destroyClickedElement;
        downloadLink.style.display = "none";
        document.body.appendChild(downloadLink);
    }

    downloadLink.click();
}

ただし、改行は保持されません。それらは document.getElementById("inputText").value; に存在します。ただし、BLOB から作成されたテキスト ファイルには含まれません。

4

3 に答える 3

37

私は同じ問題に遭遇しました。これは私のために働いているようです:

textToWrite = textToWrite.replace(/\n/g, "\r\n");
于 2014-04-23T19:35:38.553 に答える
-5

そのようなものをコードに入れる必要があります。

textToWrite.replace(/\r?\n/g, '<br />');
于 2013-10-06T15:13:38.287 に答える