IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

JavaScript Discussion :

Enregistrer le contenu d'un tableau dans un fichier


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Inscrit en
    Janvier 2009
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 60
    Points : 29
    Points
    29
    Par défaut Enregistrer le contenu d'un tableau dans un fichier
    Bonjour,
    J'ai une page web contenant un tableau html, et je voudrais enregistrer son contenu dans un fichier txt ou xml selon le choix de l'utilisateur, en cliquant sur un bouton. Le problème c'est que ça marche pas : pour IE il créé un fichier vide, et pour les autres navigateurs, pire, le bouton n'a pas d'action.
    Voici mon bout de code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
    <script language="javascript" type="text/javascript">
    function save(){
    	var res='';
    	mybody      = document.getElementsByTagName("body")[0];
    	mytable     = mybody.getElementsByTagName("table")[0];
    	myTag		= document.createElement("text");
    	//mytablebody = mytable.getElementsByTagName("tbody")[0];
    	col       = mytable.getElementsByTagName("tr");
    	SaveFrame.document.open("text/html","replace");
    	for(i=1; i < col.length; i++){
    		myrow       = mytable.getElementsByTagName("tr")[i];
    		cel = myrow.getElementsByTagName("td");
    		for(j=0; j< cel.length; j++){
    			mycel = myrow.getElementsByTagName("td")[j];
     
    	// first item element of the childNodes list of mycel
    			myceltext=mycel.childNodes[0];
    	// content of currenttext is the data content of myceltext
    			currenttext=document.createTextNode(myceltext.data);
    					SaveFrame.document.write((String)(myceltext.data));
    					SaveFrame.document.write("	") ;								
    		//	myTag.appendChild(currenttext);
    		}
    		SaveFrame.document.writeln("") ;
    	}
    	SaveFrame.document.close() ;
    	SaveFrame.focus();
    	SaveFrame.document.execCommand('SaveAs',false,'.txt') ;		
    }
    </script>
    Ici bien évidement ça contient le format txt seulement, mais comme j'ai bien indiqué on souhaite que l'on puisse enregistrer sous xml aussi.
    Merci d'avance!

  2. #2
    Membre émérite
    Inscrit en
    Septembre 2002
    Messages
    2 307
    Détails du profil
    Informations forums :
    Inscription : Septembre 2002
    Messages : 2 307
    Points : 2 814
    Points
    2 814
    Par défaut
    pour IE il créé un fichier vide
    ta sécurité laisse à désirer!

  3. #3
    Membre expérimenté
    Avatar de gwyohm
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2007
    Messages
    925
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2007
    Messages : 925
    Points : 1 333
    Points
    1 333
    Par défaut
    il vaut mieux passer par une action serveur

  4. #4
    Nouveau membre du Club
    Inscrit en
    Janvier 2009
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 60
    Points : 29
    Points
    29
    Par défaut
    Merci beaucoup pour les réponses rapides. Mais s'il vous plait détaillez un peu, je suis (très) débutant en js..
    Le code est-il totalement a rejeter?

  5. #5
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 643
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 643
    Points : 66 669
    Points
    66 669
    Billets dans le blog
    1
    Par défaut
    js n'a pas accès au disque en ecriture et n'est pas fait pour ça !

  6. #6
    Nouveau membre du Club
    Inscrit en
    Janvier 2009
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 60
    Points : 29
    Points
    29
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    js n'a pas accès au disque en ecriture et n'est pas fait pour ça !
    Merci pour l'information. Maintenant en collant vos réponse je pense que la solution serait de construire le fichier par le serveur et de le transmettre au client par téléchargement.
    Si c'est correcte, comment ceci devra se passer?

  7. #7
    Membre expérimenté
    Avatar de gwyohm
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2007
    Messages
    925
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2007
    Messages : 925
    Points : 1 333
    Points
    1 333
    Par défaut
    Citation Envoyé par solicel Voir le message
    Si c'est correcte, comment ceci devra se passer?
    Oui, c'est correcte. Vu ton avancement en js, je te conseille d'adapter ta fonction JS pour qu'elle écrive tout dans un textarea caché.
    Tu l'utilises sur un onsubmit de formulaire, et coté serveur tu récupères la valeur de la textarea, et tu l'écris dans ta réponse avec un content type text/csv

  8. #8
    Nouveau membre du Club
    Inscrit en
    Janvier 2009
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 60
    Points : 29
    Points
    29
    Par défaut
    Citation Envoyé par gwyohm Voir le message
    Oui, c'est correcte. Vu ton avancement en js, je te conseille d'adapter ta fonction JS pour qu'elle écrive tout dans un textarea caché.
    Tu l'utilises sur un onsubmit de formulaire, et coté serveur tu récupères la valeur de la textarea, et tu l'écris dans ta réponse avec un content type text/csv
    Au secours les gars, j'ai fouillé pendant des journées entières mais j'ai rien trouvé. Pourtant je me rappelle qu'avant elle marchait pour IE au moins, donc je ne suis pas loin...
    Comment corriger ce code?
    Merci.

  9. #9
    Nouveau membre du Club
    Inscrit en
    Janvier 2009
    Messages
    60
    Détails du profil
    Informations forums :
    Inscription : Janvier 2009
    Messages : 60
    Points : 29
    Points
    29
    Par défaut
    Je suis convaincu que ça sert a rien de faire ça en JS.
    C'est pas possible bien que ça me parait encore ridicule.
    Ce que je fais c'est créer un fichier a chaque exécution et l'enregistrer, et si l'utilisateur désire il peut le télécharger.
    Je le redis encore, c'est ridicule!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Free Pascal] Enregistrer le contenu de l'exécution dans un fichier
    Par mesrine dans le forum Free Pascal
    Réponses: 0
    Dernier message: 17/05/2009, 23h57
  2. Réponses: 6
    Dernier message: 01/04/2009, 09h49
  3. Enregistrer Le contenu d'un Widget dans un fichier
    Par dogua dans le forum GTK+ avec C & C++
    Réponses: 0
    Dernier message: 16/12/2008, 20h34
  4. enregistrer le contenu d'un Edit dans un fichier texte
    Par tapouni dans le forum C++Builder
    Réponses: 3
    Dernier message: 16/05/2008, 23h02

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo