Chargement de script [Résolu]

arnaultp 29 Messages postés mercredi 20 juin 2007Date d'inscription 25 juillet 2007 Dernière intervention - 4 juil. 2007 à 11:36 - Dernière réponse : arnaultp 29 Messages postés mercredi 20 juin 2007Date d'inscription 25 juillet 2007 Dernière intervention
- 5 juil. 2007 à 11:47
Bonjour à tous!
Hier soir j'ai cru avoir terminé un script. Et ce matin en le réutilisant, une erreur est intervenue. En trifouillant un peu, il a refonctionner. Puis à nouveau une erreur.
J'ai pu remarquer que c'est toujours la même erreur qui survient, et toujours quand je ferme le navigateur (IE7) et que je l'ouvre à nouveau. Et à chaque fois, le script refonctionne par je ne sais quel miracle... Bien entendu, je recherche qqch de plus stable, et surtout comprendre comment un tel phénomène peut se produire :/

Dans mon html voici l'ordre d'apparition des scripts :
<script language=javascript src="js/script1.js"></script>
<script language=javascript src="js/script2.js"></script>

script1 :

var ejs_tick_news_nom = new Array();
var ejs_tick_news_titre = new Array();
var ejs_tick_news_date = new Array();
var ejs_tick_news_heure = new Array();
var ejs_tick_news_msg = new Array();
var ejs_tick_news_url = new Array();
var ejs_tick_news_txt = new Array();

function ajax()
{
var xhr;

if(window.ActiveXObject)
{
    try
    {
        xhr = new ActiveXObject("Msxml2.XMLHTTP");
    }
    catch (e)
    {
        xhr = new ActiveXObject("Microsoft.XMLHTTP");
    }
}
else if(window.XMLHttpRequest)
{
    xhr = new XMLHttpRequest();
}
else
{ // XMLHttpRequest non supporté par le navigateur
    alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest...");
    xhr = false;
}
   
    //on définit l'appel de la fonction au retour serveur
    xhr.onreadystatechange = function() { alert_ajax(xhr); }
   
    //on appelle le fichier reponse.txt
    xhr.open("GET", "http://tidus333.free.fr/stage/intranet01/news.xml", false);
    xhr.send(null);
}

function alert_ajax(xhr)
{
    var docXML= xhr.responseXML;
    var itemsNom = docXML.getElementsByTagName("nom");
    var itemsTitre = docXML.getElementsByTagName("titre");
    var itemsDate = docXML.getElementsByTagName("date");
    var itemsHeure = docXML.getElementsByTagName("heure");
    var itemsMsg = docXML.getElementsByTagName("message");
    var itemsUrl = docXML.getElementsByTagName("url");
   
    for ( i=0 ; iscript2 :

<!--
var backgroundColor_ejs_tick_class = "black";
var position_ejs_tick_class = "absolute";
var positionTop_ejs_tick_class = "650px";
var positionLeft_ejs_tick_class = "35px";
var border_ejs_tick_class = "1px solid black";
var width_ejs_tick_class = "50%";
var height_ejs_tick_class = "14";
var font_ejs_tick_class = "bold 15px Verdana";
var textDecoration_ejs_tick_class = "none";
var color_ejs_tick_class = "white";

var color_ejs_tick_link = "white";
var textDecoration_ejs_tick_link = "none";

var color_ejs_tick_link_onmouseover = "orange";
var color_ejs_tick_link_onmouseout = "white";

/* INITIALISATION*/
ejs_tick_actual = 0;
document.write("
[ + ejs_tick_news_url[ejs_tick_actual] + " + ejs_tick_news_txt[ejs_tick_actual] + "]
");

for ( i=0 ; i<document.getElementsByTagName("div").length ; i++ )
{
    if (document.getElementsByTagName("div").item(i).className == "ejs_tick_class")
    {
        document.getElementsByTagName("div").item(i).style.backgroundColor = backgroundColor_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.position = position_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.top = positionTop_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.left = positionLeft_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.border = border_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.width = width_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.height = height_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.font = font_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.textDecoration = textDecoration_ejs_tick_class;
        document.getElementsByTagName("div").item(i).style.color = color_ejs_tick_class;
    }
}

document.getElementById("ejs_tick_link").style.color = color_ejs_tick_link;
document.getElementById("ejs_tick_link").style.textDecoration = textDecoration_ejs_tick_link;

function ejs_tick_print()
{
    ejs_tick_old = ejs_tick_actual;
    ejs_tick_actual++;
    if(ejs_tick_actual >= ejs_tick_news_url.length)
        ejs_tick_actual = 0;
    ejs_tick_slot = 0;
    ejs_tick_trans( ejs_tick_old , ejs_tick_actual );
   
    setTimeout("ejs_tick_print()", 10000);
}

function ejs_tick_trans(old, actual)
{
    ejs_tick_slot ++;
    var max_len = Math.max( ejs_tick_news_txt[actual].length , ejs_tick_news_txt[old].length ); // erreur : ejs_tick_news_txt[...].length  est Null ou n'est pas un objet
   
    if( ejs_tick_slot <= max_len )
    {
        var debut = ejs_tick_news_txt[actual].substr( 0 , ejs_tick_slot );
        var fin = ejs_tick_news_txt[old].substr( ejs_tick_slot , ejs_tick_news_txt[old].length );
        document.getElementById("ejs_tick_box").innerHTML = "" + debut + fin + "";
        setTimeout("ejs_tick_trans(" + old + ", " + actual + ")", 50);
    }
    else
    {
        document.getElementById("ejs_tick_box").innerHTML = "[ + ejs_tick_news_url[actual] + " + ejs_tick_news_txt[actual] + "]";
        document.getElementById("ejs_tick_link").style.color = color_ejs_tick_link;
        document.getElementById("ejs_tick_link").style.textDecoration = textDecoration_ejs_tick_link;        document.getElementById("ejs_tick_link").onmouseover function(){ this.style.color color_ejs_tick_link_onmouseover };        document.getElementById("ejs_tick_link").onmouseout function(){ this.style.color color_ejs_tick_link_onmouseout };
    }
}

(window.attachEvent)?
    window.attachEvent("onload",  function(){ejs_tick_print()}) :
    window.addEventListener("load", function(){ejs_tick_print()}, false);

-->

Juste une dernière précision : mon 1er script crée des variables globales qui sont ensuites utilisées dans le 2e script. J'utilise cette technique parce que plusieurs scripts utilisent les variables de mon 1er script, et j'avais vu sur un tuto qu'elle marchait parfaitement...

Merci d'avance pour votre aide
Afficher la suite 

Votre réponse

1 réponse

Meilleure réponse
arnaultp 29 Messages postés mercredi 20 juin 2007Date d'inscription 25 juillet 2007 Dernière intervention - 5 juil. 2007 à 11:47
3
Merci
J'ai finalement réussi à résoudre le problème.
Pour tous ceux qui passeraient par là et qui auraient le même problème, il s'agissait en fait de la spécificité d'AJAX de différencier les différents états au cours d'une requête envoyée serveur.
Ici mon tableau se remplissait avec des valeurs dites Null car le serveur n'avait pas encore traité la requête.
Il faut donc, pour éviter cela, réécrire le 1er script de la sorte :

function alert_ajax(xhr)
{
    var fini = false;
    if( xhr.readyState == 4 ) // lorsque la réponse à la requête a été envoyée par le serveur
    {
        var docXML = xhr.responseXML;
        var itemsNom = docXML.getElementsByTagName("nom");
        var itemsTitre = docXML.getElementsByTagName("titre");
        var itemsDate = docXML.getElementsByTagName("date");
        var itemsHeure = docXML.getElementsByTagName("heure");
        var itemsMsg = docXML.getElementsByTagName("message");
        var itemsUrl = docXML.getElementsByTagName("url");
       
        for ( var i=0 ; i

Merci arnaultp 3

Avec quelques mots c'est encore mieux Ajouter un commentaire

Codes Sources a aidé 92 internautes ce mois-ci

Commenter la réponse de arnaultp

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.

Le fait d'être membre vous permet d'avoir des options supplémentaires.