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

jQuery Discussion :

récupérer le contenu d'un div , balises y compris


Sujet :

jQuery

  1. #1
    Membre émérite Avatar de patrickbaras
    Homme Profil pro
    Informaticien (à sa mémère).
    Inscrit en
    Septembre 2010
    Messages
    525
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Informaticien (à sa mémère).
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 525
    Par défaut récupérer le contenu d'un div , balises y compris
    comment récupérer le contenu d'un div , balises y compris.
    exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <div id='monTest'>
    	<div>mon texte</div>
    </div>
    donne
    "mon texte"
    donne
    "<div>mon texte</div>"
    je voudrais récuperer
    "<div id='monTest'>
    <div>mon texte</div>
    </div>"
    merci d'avance pour l'aide qu'il vous plaira de m'apporter.

  2. #2
    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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    avec une extension
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    	jQuery.fn.outerHtml=function(){
    		return $('<div/>').append(this.clone()).html()
     	}
     
    	$(function(){
    	 	alert($('#monTest').outerHtml())
    	})
    </script>
    </head>
    <body>
    <div id='monTest'>
    	<div>mon texte</div>
    </div>
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  3. #3
    Membre émérite Avatar de patrickbaras
    Homme Profil pro
    Informaticien (à sa mémère).
    Inscrit en
    Septembre 2010
    Messages
    525
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Informaticien (à sa mémère).
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 525
    Par défaut
    merci
    mais dans mon exemple c'est un <div> mais je pensai a une solution plus générale qui fonctionnerai avec toutes les balises

    j'ai trouvé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $("#montest")[0].outerHTML
    qui retourne ce que je voulais

    merci de votre aide

  4. #4
    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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    Ce serait bien que tu essayes au moins le code proposé ...
    Mon extension fonctionne avec tout type de balise ...
    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
     
    <script type="text/javascript">
    	jQuery.fn.outerHtml=function(){
    		return $('<div/>').append($(this).clone(true)).html()
     
     	}
    	$(function(){
     	$('.monTest').each(function(){ alert($(this).outerHtml()) })
    	})
    </script>
    </head>
    <body>
    <div class='monTest'>
    	<div>mon texte</div>
    </div>
    <fieldset class='monTest'>
    	<div>mon texte</div>
    </fieldset>
    <span class='monTest'>
    	<div>mon texte</div>
    </span>


    Pour ce qui est de ta solution
    te permet de retourner au niveau du DOM en ressortant dont de la collection JQUERY et de retomber sur les méthodes natives de javascript

    Personnellement j'ai tésté le outerHTML de javascript et il n'est pas crossbrowser ...

    Après à toi de voir ton besoin ..
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  5. #5
    Membre émérite Avatar de patrickbaras
    Homme Profil pro
    Informaticien (à sa mémère).
    Inscrit en
    Septembre 2010
    Messages
    525
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Informaticien (à sa mémère).
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 525
    Par défaut
    merci pour ton code il me sera certainement utile dans d'autre cas
    mais d'une selection sur un ID
    je passe a une selection sur une CLASS

    dans mon exemple j'ai simplifié

    mais je peux aussi avoir besoin de retrouver par exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href='' id='...'></a>
    ou
    effectivement ma solution n'est pas compatible avec tt les browsers
    mais comme il s'agit d'une application intranet je peux me permettre ce genre d'incompatibilité

  6. #6
    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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    Tu es juste désépérant ...
    Rien a voir avec l'id ou la classe ...
    c'était juste un exemple, mais à priori je t'ai perdu en route

    voici avec des id ...
    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
    32
    33
    34
     
    <script type="text/javascript">
    	jQuery.fn.outerHtml=function(){
    		return $('<div/>').append($(this).clone(true)).html()
     
     	}
     
    	$(function(){
     	 alert( $('#monTest1').outerHtml()) ;
        alert( $('#monTest2').outerHtml()) 
        alert( $('#monTest3').outerHtml()) 
    alert( $('#monTest4').outerHtml()) 
        alert( $('#monTest5').outerHtml()) 
     
      $('[id^=monTest]').each( function(){
      alert('dans une boucle aussi \n' +$(this).outerHtml())
      })
     
     
    	})
    </script>
    </head>
    <body>
    <div id='monTest1'>
    	<div>mon texte</div>
    </div>
    <fieldset id='monTest2'>
    	<div>mon texte</div>
    </fieldset>
    <span id='monTest3'>
    	<div>mon texte</div>
    </span>
    <a id="monTest4">un lien href</a>
    <p id="monTest5">une balise p</p>

    [edit] j'ai rajouté une balise a et une balise p pour te rassurer ...
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  7. #7
    Membre émérite Avatar de patrickbaras
    Homme Profil pro
    Informaticien (à sa mémère).
    Inscrit en
    Septembre 2010
    Messages
    525
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Informaticien (à sa mémère).
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 525
    Par défaut
    Désolé pour le désespoir provoqué.
    Je ne fait du jquery que depuis le début de la semaine.

  8. #8
    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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    cela ne t'empêche pas au moins de tester les codes fournis ...
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  9. #9
    Membre émérite Avatar de patrickbaras
    Homme Profil pro
    Informaticien (à sa mémère).
    Inscrit en
    Septembre 2010
    Messages
    525
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Informaticien (à sa mémère).
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 525
    Par défaut
    bonjour:
    j'ai essayé et modifié ton code pour qu'il fonctionne comme $("#montest")[0].outerHTML
    c-a-d récuperer le code mais aussi pouvoir le changer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    		jQuery.fn.outerHTML=function(param){
    			if(param!='' && param!=null)
    			{
    				$(this).replaceWith(param);
    				return true;
    			}else{
    				return $('<div/>').append($(this).clone(true)).html()
    			}
    			return false;
    		}

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alert($("#madiv2").outerHTML());
    retourne le contenu

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $("#madiv2").outerHTML("<h1>test</h1>");
    change le contenu

    merci pour ton aide

  10. #10
    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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    Cela ne fonctionnera pas comme html(), tu n epourras pas retourner l'element en fin de fonction afin de pouvoir chainer les fonctions comme ceci par exemple

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $("#h3").outerHTML("<h1>hello world</h1>").css('color','red');
    tu ne peux que modifier l'élément, mais pas le retourner car tu ne peux pas changer le this au sein de la fonction et le retourner modifié
    Ceci ne retourne pas l'element
    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
    <script type='text/javascript'>
     
    		jQuery.fn.outerHTML=function(param){
    			if(param!='' && param!=null)
    			{
    			return $(this).replaceWith(param);
    			}
    			else{
    				return $('<div/>').append($(this).clone(true)).html()
    			}
    		}	
     
    $(function(){
    $("#h3").outerHTML("<h1>hello world</h1>").css({'color':'red'});
    })
    </script>
    </head>
    <body>
    <h3 id="h3">test</h3>
    </body>
    </html>
    C'est d'ailleurs a mon avis pour cela que outerHTML n'existe pas en Jquery
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

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

Discussions similaires

  1. Réponses: 7
    Dernier message: 03/05/2014, 11h50
  2. Récupérer le contenu de plusieurs div
    Par michel.di dans le forum jQuery
    Réponses: 4
    Dernier message: 27/09/2011, 14h40
  3. Récupérer le contenue d'un div d'une page HTML
    Par avogadro dans le forum Windows Forms
    Réponses: 1
    Dernier message: 10/09/2007, 09h25
  4. Récupèrer le contenu d'un DIV
    Par gotcha007 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 10/03/2006, 14h00
  5. [Balise XML] Comment récupérer le contenu entre 2 balise?
    Par ZoumZoumMan dans le forum C++Builder
    Réponses: 5
    Dernier message: 05/03/2004, 16h36

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