Chargement de script

Résolu
arnaultp Messages postés 29 Date d'inscription mercredi 20 juin 2007 Statut Membre Dernière intervention 25 juillet 2007 - 4 juil. 2007 à 11:36
arnaultp Messages postés 29 Date d'inscription mercredi 20 juin 2007 Statut Membre Dernière intervention 25 juillet 2007 - 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

1 réponse

arnaultp Messages postés 29 Date d'inscription mercredi 20 juin 2007 Statut Membre Dernière intervention 25 juillet 2007
5 juil. 2007 à 11:47
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
3
Rejoignez-nous