web-dev-qa-db-fra.com

Comment exporter le contenu source de div en fichier texte/html

Disons que j'ai <div id="main"> ... Some html ...</div> et que je dois prendre le code HTML dans cette div, le placer dans un fichier et forcer son téléchargement au format TXT. Comment cela peut-il être fait? Devrais-je utiliser PHP ou Javascript? Je préfère javascript.

11
023023

Vous pouvez utiliser quelque chose comme ceci:

Mise à jour de jsfiddle avec download btn (jquery)

Jsfiddle initial avec js simple et autoexecution

html

<div id="main">
    <span>Hey there</span>
</div>

html - Edit (Ajout d'un lien pour effectuer cette action) 

<a href="#" id="downloadLink">Download the inner html</a>

Js

function downloadInnerHtml(filename, elId, mimeType) {
    var elHtml = document.getElementById(elId).innerHTML;
    var link = document.createElement('a');
    mimeType = mimeType || 'text/plain';

    link.setAttribute('download', filename);
    link.setAttribute('href', 'data:' + mimeType  +  ';charset=utf-8,' + encodeURIComponent(elHtml));
    link.click(); 
}

var fileName =  'tags.html'; // You can use the .txt extension if you want

JS - Éditer

Comme vous avez dit dans les commentaires que vous utilisez jQuery, j'appellerai cette fonction à partir d'un gestionnaire, au lieu de l'appeler directement.

$('#downloadLink').click(function(){
    downloadInnerHtml(fileName, 'main','text/html');
});

Vous pouvez télécharger le texte, il suffit de supprimer le troisième argument de function. Le paramètre par défaut, "text/plain", sera utilisé, et d'ajouter l'extension .txt au nom de fichier au lieu de html.

Note J'ai modifié cette réponse car la personne qui avait posé la question avait commenté qu'elle cherchait comment la faire fonctionner avec un gestionnaire, il la faisait fonctionner, mais juste au cas où . Le code original est dans le jsfiddle

25
Zagen

Le prévu peut être atteint avec une méthode javascript. La fonction suivante vous permettra d’ajouter un nom personnalisé avec lequel vous souhaitez télécharger votre fichier texte.

function saveTextAsFile()
{
    //inputTextToSave--> the text area from which the text to save is
    //taken from
    var textToSave = document.getElementById("inputTextToSave").value;
    var textToSaveAsBlob = new Blob([textToSave], {type:"text/plain"});
    var textToSaveAsURL = window.URL.createObjectURL(textToSaveAsBlob);
    //inputFileNameToSaveAs-->The text field in which the user input for 
    //the desired file name is input into.
    var fileNameToSaveAs = document.getElementById("inputFileNameToSaveAs").value;

    var downloadLink = document.createElement("a");
    downloadLink.download = fileNameToSaveAs;
    downloadLink.innerHTML = "Download File";
    downloadLink.href = textToSaveAsURL;
    downloadLink.onclick = destroyClickedElement;
    downloadLink.style.display = "none";
    document.body.appendChild(downloadLink);

    downloadLink.click();
}

function destroyClickedElement(event)
{
    document.body.removeChild(event.target);
}

Ce qui précède est dérivé de ici .

4
user6798473

Mise à jour pour la fonction Zagen. L'original ne fonctionnera pas dans IE 10-11:

function downloadInnerHtml(filename, elId, mimeType) {
    var elHtml = document.getElementById(elId).innerHTML;
    if (navigator.msSaveBlob) { // IE 10+ 
        navigator.msSaveBlob(new Blob([elHtml], { type: mimeType + ';charset=utf-8;' }), filename);
    } else {
        var link = document.createElement('a');
        mimeType = mimeType || 'text/plain';

        link.setAttribute('download', filename);
        link.setAttribute('href', 'data:' + mimeType  +  ';charset=utf-8,' + encodeURIComponent(elHtml));
        link.click(); 
    }
}
1
cratu

Voici mon code complet, j'espère que cela pourra être utile à quelqu'un dans la même situation

<!-- SAVE AS HTML OR TXT FILE -->
    <script type="text/javascript">


            // Wait for the page to load first
            window.onload = function() {

              //Get a reference to the link on the page
              // with an id of "exportxt"
              var a = document.getElementById("exportxt");

              //Set code to run when the link is clicked
              // by assigning a function to "onclick"
              a.onclick = function() {

                // Your code here...


    function downloadInnerHtml(filename, elId, mimeType) {
        var elHtml = document.getElementById(elId).innerHTML;
        var link = document.createElement('a');
        mimeType = mimeType || 'text/plain';
        link.setAttribute('download', filename);
        link.setAttribute('href', 'data:' + mimeType  +  ';charset=utf-8,' + encodeURIComponent(elHtml));
        link.click(); 
    }
    var fileName =  'myexportedhtml.txt'; // You can use the .txt extension if you want
    downloadInnerHtml(fileName, 'editor','text/plain');
                //If you don't want the link to actually 
                // redirect the browser to another page, then
                // return false at the end of this block.
                // Note that this also prevents event bubbling,
                // which is probably what we want here, but won't 
                // always be the case.
                return false;
              }
            }

    </script>


    <a id="exportxt" href="#">SAVE PROJECT IN TXT FILE</a> 

<div id="editor"><p style="font-family:'Courier New', Courier, monospace; font-size:11px; color:#663300">Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam luctus facilisis ante id luctus. Aliquam vestibulum, dui in pulvinar facilisis, felis nisl viverra nisl, nec ultrices neque tortor eget erat. Vivamus vel leo vehicula, condimentum quam aliquam, congue mauris. Pellentesque id lectus id nulla molestie vehicula sed at velit. Maecenas sit amet tristique nunc, in lobortis mi. Integer in turpis odio. Duis eget urna vestibulum, venenatis justo et, semper neque. Suspendisse in ante massa. Aenean massa nisl, tincidunt id nisl eu, convallis lobortis augue. Integer blandit augue eget nunc condimentum consectetur. Duis gravida nisl hendrerit, sagittis orci in, sollicitudin risus. Nullam elementum sem nec nunc facilisis, et semper metus tincidunt.

Phasellus ornare quis ipsum non scelerisque. In sollicitudin est placerat nibh porttitor pretium. Phasellus ac purus nulla. Phasellus in enim vel leo viverra sodales eget sit amet ante. Sed ultrices elementum nibh, tristique euismod nunc volutpat sit amet. Suspendisse potenti. Morbi feugiat diam tristique, euismod dui in, mattis diam. Vestibulum euismod commodo cursus. Proin posuere libero vitae purus blandit, in posuere erat malesuada. Donec ultrices vel velit in feugiat. Vestibulum suscipit erat urna, bibendum vestibulum dui varius sit amet.</p></div>

CRÉDITS, CETTE RÉPONSE: Comment utiliser un lien pour appeler JavaScript?

0
023023