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 :

ouvrir un lien enfant dans un div


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé

    Profil pro
    Inscrit en
    Avril 2004
    Messages
    421
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2004
    Messages : 421
    Par défaut ouvrir un lien enfant dans un div
    bonjour,

    voila, j'ai le script suivant, il ne fait rien de bien compliquer, (c'est un test) mais j'ai deja un bug,

    En fiat, il met dans un div, une page.php qui se trouve sur le server php.
    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
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
     
    <!---ceci est la page index.php -->
    <html>
    	<head>
    		<title>Tutoriel Ajax (XHTML + JavaScript + XML)</title>
    		<script type='text/JavaScript'>
    			var xhr = null; 
     
    	 		function getXhr(){
    				if(window.XMLHttpRequest) // Firefox et autres
    				   xhr = new XMLHttpRequest(); 
    				else if(window.ActiveXObject){ // Internet Explorer 
    				   try {
    			                xhr = new ActiveXObject("Msxml2.XMLHTTP");
    			            } catch (e) {
    			                xhr = new ActiveXObject("Microsoft.XMLHTTP");
    			            }
    				}
    				else { // XMLHttpRequest non supporté par le navigateur 
    				   alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
    				   xhr = false; 
    				} 
    			}
     
    			/**
    			* Méthode qui sera appelée sur le click du bouton
    			*/
    			function go(){
    				getXhr()
    				// On défini ce qu'on va faire quand on aura la réponse
    				xhr.onreadystatechange = function(){
    					// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    					if(xhr.readyState == 4 && xhr.status == 200){
     
    					document.getElementById("first").innerHTML = xhr.responseText;
     
     
    					}
    				}
    				xhr.open("GET","test.php",true);
    				xhr.send(null);
    			}
    		</script>
    	</head>
    	<body>
     
    	<div id="first" onclick="go()" style="position: absolute; top: 176px; left: 33px; width: 993px; height: 398px; background-color: rgb(18, 52, 86);"></div>
     
     
    	</body>
    </html>
    ceci fonctionne parfaitement bien (merci au tuto dev.) mlais le hic, c'est que si test.php a du code html et a un lien. et que l'on click sur le lien, il ouvre en grand et non plus dans le div.

    j'aurais boulu savoir si il y a moyen d'intercepté tout les clicks qui se trouve dans le div pour pouvoir les traité avec xhr et donc les reouvrir dans le div (et donc, ne pas changer de page)

    suis-je clair???

    merci


    a+++

  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
    heu pas très ...
    supprime les balises du response ...
    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 éclairé

    Profil pro
    Inscrit en
    Avril 2004
    Messages
    421
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2004
    Messages : 421
    Par défaut
    le probleme, c'est que je n'ai aps acces a responce, dans le sens je ne sais pas la modifier.

  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
    quels sont les élements du response qui posent problème ???
    quelles balises ???

    biensur que tu as accès au response !!!
    le principe serait de virer les balises génantes ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    var ContenuaInserer=xhr.responseText.replace(balisegenante,'');
    document.getElementById("first").innerHTML = ContenuaInserer
    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
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 684
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 684
    Par défaut
    comprends bien que tu n'ouvres pas "une page dans ta page" mais simplement un bloc de html;
    donc:
    - ce qui apparaît dans ton div doit être maîtrisé a priori;
    - tu peux effectivement réaffecter à ce même contenu des événements (conditionnels... vu que le contenu n'existe pas toujours) faisant appel à xhr; mais vas-y doucement;

  6. #6
    Membre éclairé

    Profil pro
    Inscrit en
    Avril 2004
    Messages
    421
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2004
    Messages : 421
    Par défaut
    je crois que j'ai trouvé mieux, un div contenant un iframe
    et avec ca

    http://ditch.developpez.com/javascri...pdate/exemple/

    ca devrait fonctioner.

    reste plus qu'a essayer

    merci

    a+++

  7. #7
    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
    ouiap si tu prends un iframe tu affiche une page html...
    parcontre plus besoin d'ajax ...
    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 !

  8. #8
    Membre éclairé

    Profil pro
    Inscrit en
    Avril 2004
    Messages
    421
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Avril 2004
    Messages : 421
    Par défaut
    ajax n'est pas un (trop gros) probleme.

    mais parcontre, dans le lien que j'ai donné (http://ditch.developpez.com/javascript/partialupdate/)

    il utilise

    ChangeFrameLocation('FrameMiseAJour', 'ExempleSimpleContenu.html');

    or chez moi, cela ne fonctionne pas, (linux ubuntu firefox.)

    je suis obliger de passer par document.getElementById("FrameMiseAJour").src = "file.html";

    est ce equivalent???

  9. #9
    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
    ChangeFrameLocation n'est a ma connaissance pas une instruction javascript mais doit faire partie d'un librairie ou une fonction perso ...
    ta methode est tout à fait valable ...
    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 !

  10. #10
    Expert confirmé
    Avatar de Ditch
    Inscrit en
    Mars 2003
    Messages
    4 160
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Mars 2003
    Messages : 4 160
    Par défaut
    Citation Envoyé par SpaceFrog
    ChangeFrameLocation n'est a ma connaissance pas une instruction javascript mais doit faire partie d'un librairie ou une fonction perso ...
    ta methode est tout à fait valable ...
    Exactement. ChangeFrameLocation renferme une série de choses. J'ai fait cela partout. Pq? Simplement que lors que Firefox 28 sortira (j'ai le temps ) et si il ne tient plus compte du .src, je n'ai qu'un script à changer et pas faire la modification au travers de tout le fichier.


    Ceci dit, je n,e fais qu'appeler ce la mm chose que toi dans cette fonction

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

Discussions similaires

  1. script pour ouvrir lien/LINK dans une DIV
    Par santaflam dans le forum Général JavaScript
    Réponses: 17
    Dernier message: 06/07/2010, 15h54
  2. code html pour ouvrir un lien URL dans une autre fenêtre de l'explorateur internet ?
    Par Dukey dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 20/02/2008, 18h50
  3. lien inaccessible dans des div imbriqués
    Par zadlaure dans le forum Mise en page CSS
    Réponses: 10
    Dernier message: 18/06/2007, 16h00
  4. Propriétés des liens contenu dans un div
    Par Anubis dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 03/04/2007, 14h44
  5. [HTML]ouvrir une page html dans une div
    Par Phenomenium dans le forum Balisage (X)HTML et validation W3C
    Réponses: 5
    Dernier message: 16/01/2006, 17h23

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