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 :

Préchargement d'une page html en cache (object, iframe)


Sujet :

JavaScript

  1. #1
    Invité
    Invité(e)
    Par défaut Préchargement d'une page html en cache (object, iframe)
    Bonjour,
    savez-vous s'il existe une méthode pour charger dans le cache du navigateur une page html complete qui n'a pas encore été visitée ?

    Je sais que pour précharger une image dans le cache on peut appeler un script contenant le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ma_var = new Image();
    ma_var.src = "/images/ma_photo.jpeg";
    Est - il possible de l'adapter pour une page complète ? Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    ma_var = new window();
    ma_var.src = "/repertoire/ma_page.html";
    ------------------------------------------------------------

    PS : en farfouillant j'ai vu ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function include(id,url)
    {
      var xml = new XMLHttpRequest();
      xml.open("GET",url,false);
      xml.send(null);
      document.getElementById(id).innerHTML=xml.responseText;
    }
    ça peut m'être utile ?
    Dernière modification par Invité ; 15/10/2008 à 20h09.

  2. #2
    Rédacteur
    Avatar de bigboomshakala
    Homme Profil pro
    Consultant Web .NET
    Inscrit en
    Avril 2004
    Messages
    2 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Web .NET
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2004
    Messages : 2 077
    Points : 2 757
    Points
    2 757
    Par défaut
    ya bien la technique de l'iframe. je ne sais pas s'il y a plus "propre"
    tu place un iframe dans la page, display none, et tu charges la 2è page dedans

  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 640
    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 640
    Points : 66 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    Je ne vois pas mieux que la proposition de BBS

  4. #4
    Invité
    Invité(e)
    Par défaut
    J'ai trouvé ! (avec validation xhtml 1.1), c'est pas très propre mais bon ... les navigateur qui supportent pas la balise <object> n'afficheront rien ...

    Je m'inquiète plus pour les navigateurs textes, oraux et braille (ils risquent de ne pas interpréter le dimensionnement à zero pixels de l'élément <object> ni le retrait de 100 pixels vers le haut ...)
    Pensez - vous que les définitions css dans l'entête me mettront à l'abris ?

    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
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <title>Titre</title>
    <meta http-equiv="content-type" content="application/xhtml+xml;charset=utf-8" />
    <style type="text/css" media="aural">
    <!--
    object.prechargement{display: none;}
    -->
    </style>
    <style type="text/css" media="braille">
    <!--
    object.prechargement{display: none;}
    -->
    </style>
    <style type="text/css" media="tty">
    <!--
    object.prechargement{display: none;}
    -->
    </style>
    <style type="text/css" media="screen">
    <!--
    object.prechargement{position: absolute; top: -100px;}
    -->
    </style>
    </head>
    <body>
     
    <p>Paragraphe 1</p>
     
    <div>
    <object class="prechargement" data="http://www.google.fr/" width="0" height="0" type="text/html"></object>
    </div>
     
    <p>Paragraphe 2</p>
     
    </body>
    </html>

  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 640
    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 640
    Points : 66 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    autant mettre des iframes ...

  6. #6
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Bonjour,
    Citation Envoyé par hellfoust Voir le message
    PS : en farfouillant j'ai vu ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function include(id,url)
    {
      var xml = new XMLHttpRequest();
      xml.open("GET",url,false);
      xml.send(null);
      document.getElementById(id).innerHTML=xml.responseText;
    }
    ça peut m'être utile ?
    Pas gagné : c'est de l'Ajax => mise en cache sur le serveur, mais ce que reçoit le nav n'est qu'une chaine de caractères (même si elle représente le contenu de ta page HTML). De plus, en l'état, tu ne chargeras pas les include éventuelles, les images, tu ne pourras pas gérer de <form> etc.

    Le plus simple reste l'iframe cachée de BigBoomS ...

    A+

  7. #7
    Invité
    Invité(e)
    Par défaut
    Merci pour vos réponses, pour la balise iframe, elle ne passe pas le validateur, elle a été virée des spécifications. Quand au AJAX, si c'est "compliqué", je ne vais pas me plonger dedans pour ce rafistolage.
    A la base je voulait faire des pages longues et peu nombreuses (car je pensait qu'il y avait un moyen "règlementaire" de mettre des pages en cache), mais je vais revoir ma stratégie.

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

Discussions similaires

  1. Mise en cache d'une page html
    Par Christophe59 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 02/04/2012, 16h28
  2. Récupérer le code d'une page html contenue dans un balise object sous I
    Par olivier21c dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 10/05/2008, 16h48
  3. [HTML] [Firefox][IE] Vidéo sur une page html en Object ou embed.
    Par Maxoo dans le forum Balisage (X)HTML et validation W3C
    Réponses: 15
    Dernier message: 10/07/2007, 08h53
  4. [VB.Net] Comment generer une page html dynamiquement ?
    Par Anonymous dans le forum ASP.NET
    Réponses: 3
    Dernier message: 13/03/2003, 10h22
  5. [CR] Tranfert de formulaire a travers une page HTMl
    Par LIEU dans le forum SAP Crystal Reports
    Réponses: 3
    Dernier message: 12/09/2002, 08h37

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