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

Contribuez Discussion :

Ajax sans Ajax c'est presque du Gérard Majax


Sujet :

Contribuez

  1. #1
    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 637
    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 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Par défaut Ajax sans Ajax c'est presque du Gérard Majax
    Attention ceci n'est pas une révolution et ne permet de contourner qu'un tout petit blocage dû à une tentative de connexion crossdomain en local.
    Je me suis en effet aperçu qu'une tentative de connexion à une page en local depuis un html en local avec ajax me retournait un accès refusé justement à cause de la sécurité crossdomain si je ne passais pas par mon serveur en local.
    Cette solution permet de contourner ce blocage et permet en réseau, sans serveur web et sans ajax de récupérer des données (ici en json ) par l'intermédiaire d'un page html:

    L'astuce consiste en une bidouille avec in iframe.
    Et du coup on n'échappe pas au refus d'accès si la page en src de l'iframe est hors domaine, mais on y accès si cela reste sur le reseau.

    voici le code html:
    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
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>Nouvelle page 1</title>
    <script type="text/javascript">
    function bar(){
    var recup=self.parent.foo.document.body.innerHTML.replace(/(^<pre>)|(<\/pre>$)/gi,'')
    json= eval('('+recup+')')
    alert(json.two)
    }
    </script>
    </head>
    <body onload="bar()">
    <iframe name='foo' id="foo" src="testjson.txt" width="0" height="0" style="display:none">
    </iframe>
    </body>
    </html>
    ici le fichier texte:
    ici l'exemple est sur un fichier texte, l'affichage dans l'iframe rajoute des balises pre...
    JE vais retravailler le code pour qu'il puisse accepter du html...
    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 !

  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 637
    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 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Par défaut
    voici une version avec option de retour json ou texte
    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
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>Nouvelle page 1</title>
    <script type="text/javascript">
     
    function myAjax(format){
    var recup=self.parent.foo.document.body.innerHTML.replace(/(^<pre>)|(<\/pre>$)/gi,'')
    var temp
     switch(format){
    	case ('json') :	temp= eval('('+recup+')');
          	               	break;
     
    	case('txt') :		temp= recup;
    					break;
     
    	default :		temp= recup;
    	}
    	return temp;
    }
    </script>
    </head>
    <body onload="truc=myAjax('json'); machin =myAjax('txt');alert('avec l\'option json, je recupère un objet json: \t truc[\'two\']='+truc.two+'\navec l\'option txt je recupère le texte :\t'+machin)">
    <iframe name='foo' id="foo" src="testjson.txt" width="300" height="500" style="display:none">
    </iframe>
    </body>
    </html>
    On pourrait alors imagine passe en paramètre de la fonction le fichier ...
    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
    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 637
    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 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Par défaut
    Suite à la forte demande j'ai rajouté la possibilité de recupérer un array en specifiant un separateur

    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
    <script type="text/javascript">
    function myAjax(format){
    var recup=self.parent.foo.document.body.innerHTML.replace(/(^<pre>)|(<\/pre>$)/gi,'')
    var temp
     switch(format){
    	case ('json') :	temp= eval('('+recup+')');
          	               	break;
     
    	case('txt') :		temp= recup;
    					break;
     
    	case('sep'):	temp=recup.split(arguments[1])
    	default :		temp= recup;
    	}
    	return temp;
    }
    </script>
    utilisation:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    truc=myAjax('sep','\r\n');alert(truc)
    ici je choisis le retour ligne comme separateur
    truc est alors un array des lignes du fichier texte
    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 !

  4. #4
    Membre éclairé

    Femme Profil pro
    Experte JS / Conseillère en best practices / Chercheuse en programmation
    Inscrit en
    Octobre 2007
    Messages
    741
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 43
    Localisation : Belgique

    Informations professionnelles :
    Activité : Experte JS / Conseillère en best practices / Chercheuse en programmation
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Octobre 2007
    Messages : 741
    Points : 808
    Points
    808
    Par défaut
    Cette astuce est sympa mais tu aurais pu faire plus propre qu'avec des iframes.

    Avec du SVG ou des objects...
    Afin d'obtenir plus facilement de l'aide, n'hésitez pas à poster votre code de carte bancaire

    Mon GitHub

    Une alternative à jQuery, Angular, Vue.js, React, ... ? Testez anticore, en quelques secondes à peine !
    (Contributions bienvenues)

  5. #5
    Expert confirmé
    Avatar de RomainVALERI
    Homme Profil pro
    POOête
    Inscrit en
    Avril 2008
    Messages
    2 652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : POOête

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 652
    Points : 4 164
    Points
    4 164
    Par défaut
    Citation Envoyé par Lcf.vs Voir le message
    Cette astuce est sympa mais tu aurais pu faire plus propre qu'avec des iframes.

    Avec du SVG ou des objects...
    Ouais ! ...en plus y'a pas de touche "Capuccino" ni d'option "mains libres" alors c'est nul

    T'as pas fini, oui ? ^^
    C'est des coups à nous le décourager, ça !

    ps : j'ose pas raconter à ma femme la vanne "ajax / gérard majax" sinon je vais prendre un bide ...mais elle sait pas ce qu'elle perd

    ...pour les linguistes et les curieux >>> générateur de phrases aléatoires

    __________________

  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 637
    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 637
    Points : 66 658
    Points
    66 658
    Billets dans le blog
    1
    Par défaut
    Oulà tu déterres un truc qui date de plus d'un an là...
    De mémoire j'ai aussi testé avec la balise object. Faudrait que je retrouve les sources, Mais si je n'ai pas proposé la version object c'est qu'a mon avis elle fonctionnait mois bien.

    Sinon pour ceux qui connaissent "y'a un truc"
    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 !

Discussions similaires

  1. [AJAX] Rafrichir en ajax sans submit
    Par niceen dans le forum Général JavaScript
    Réponses: 10
    Dernier message: 06/02/2008, 09h57
  2. liste liée sans ajax
    Par ph_anrys dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 15/11/2007, 15h56
  3. Autocomplétion sans ajax
    Par bbo1991 dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 01/08/2007, 17h16
  4. [JS->PHP] sans ajax si possible
    Par escteban dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 12/06/2007, 20h43

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