Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [JS] Funkcja od ajax'a
Eagle
post
Post #1





Grupa: Zarejestrowani
Postów: 170
Pomógł: 14
Dołączył: 16.03.2007

Ostrzeżenie: (0%)
-----


Witam. Dopiero zaczynam swoją przygodę z ajaxem.
Pogrzebałem trochę i znalazłem dość prosty przykład jak załadować kawałek xml'a http://developer.mozilla.org/en/AJAX/Getting_Started

Przerobiłem skrypt podany na stronie i wyszło mi coś takiego
Kod
function loadPage(pageUrl,htmlTag,xmlTag)
{
    if(xmlTag == undefined)
    {
        xmlTag = htmlTag;
    }

    var httpRequest;
    if (window.XMLHttpRequest)
    {
        httpRequest = new XMLHttpRequest();
        if (httpRequest.overrideMimeType)
        {
            httpRequest.overrideMimeType('text/xml');
        }
    }
    else
    {
        if (window.ActiveXObject)
        {
            try
            {
                httpRequest = new ActiveXObject("Msxml2.XMLHTTP");
            }
            catch (e)
            {
                try
                {
                    httpRequest = new ActiveXObject("Microsoft.XMLHTTP");
                }
                catch (e) {}
            }
        }
    }

    if (!httpRequest)
    {
        alert('Giving up :( Cannot create an XMLHTTP instance');
        return false;
    }
    
    httpRequest.onreadystatechange = alertContents(httpRequest,htmlTag,xmlTag);
    httpRequest.open('GET', pageUrl, true);    
    httpRequest.send('');
}

function alertContents(httpRequest,htmlTag,xmlTag)
{
    if (httpRequest.readyState == 4)
    {
        if (httpRequest.status == 200)
        {
            var xmldoc = httpRequest.responseXML;
            var root_node = xmldoc.getElementsByTagName(xmlTag).item(0);
            var data = document.getElementById(htmlTag);
            data.innerHTML = root_node.firstChild.data;
        }
        else
        {
            alert('There was a problem with the request.');
        }
    }
}



Plik pole1.xml
  1. <?xml version="1.0" ?>
  2. <pole1>Jakiś tekst ble ble bel</pole1>


HTML:
  1. <head>
  2. <title>Moj pierwszy ajax!</title>
  3. <script type="text/javascript" src="jax.js"></script>
  4. </head>
  5. <body>
  6. <a href="" onClick="loadPage('pole1.xml','pole1','pole1')">Cos1</a>
  7. <br />
  8. <br />
  9. <div id="pole1"></div>
  10. </body>
  11. </html>


Jednak po kliknięciu na link cała strona się przeładowuje - nie wyświetla danych z pliku xml
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 5)
wookieb
post
Post #2





Grupa: Moderatorzy
Postów: 8 989
Pomógł: 1550
Dołączył: 8.08.2008
Skąd: Słupsk/Gdańsk




1) Zainstaluje firebuga on ci pokaze wszystkie bledy
2) Nie zaczynaj tak ajaxa. Użyj jquery albo advajax a potem dopiero cwicz sobie "flakowate" oprogramowanie ajaxa.
Go to the top of the page
+Quote Post
Eagle
post
Post #3





Grupa: Zarejestrowani
Postów: 170
Pomógł: 14
Dołączył: 16.03.2007

Ostrzeżenie: (0%)
-----


1) Mam zainstalowanego - nie zwraca błędów
2) Zaraz poszukam (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)


Po takiej drobnej zmianie
Kod
    httpRequest.open('GET', pageUrl, true);    
    httpRequest.send('');
    httpRequest.onreadystatechange = alertContents(httpRequest,htmlTag,xmlTag);

i śledzeniu krok po kroku (na firebugu) strona jest wczytywana prawidłowo.
Go to the top of the page
+Quote Post
_VBService_
post
Post #4





Grupa: Zarejestrowani
Postów: 4
Pomógł: 2
Dołączył: 12.10.2008

Ostrzeżenie: (0%)
-----


Masz błąd w składni pliku xml. (IMG:http://forum.php.pl/style_emoticons/default/snitch.gif)
Zaraz ci napisze sampla (IMG:http://forum.php.pl/style_emoticons/default/rolleyes.gif)
Go to the top of the page
+Quote Post
Eagle
post
Post #5





Grupa: Zarejestrowani
Postów: 170
Pomógł: 14
Dołączył: 16.03.2007

Ostrzeżenie: (0%)
-----


Czekam z niecierpliwością (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)

Zauważyłem że po dodaniu 2 alertów na początek funkcji alertContents
Kod
{
    alert('ReadyState: ' + httpRequest.readyState);
    alert('Status: ' + httpRequest.status);
    ...

wszystko chodzi poprawnie.
Go to the top of the page
+Quote Post
_VBService_
post
Post #6





Grupa: Zarejestrowani
Postów: 4
Pomógł: 2
Dołączył: 12.10.2008

Ostrzeżenie: (0%)
-----


Korzystam w samplu z www.advajax

Folder powinien zawierać pliki:
pole1.xml
Kod
<?xml version="1.0" encoding="utf-8" ?>
<root>
  <pole1>Jakiś tekst ble ble bel</pole1>
</root>


index.htm
Kod
       <html>
       <head>
       <title>Moj pierwszy ajax!</title>
       <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
       <script type="text/javascript" src="ajax.action.js"></script>
       <script type="text/javascript" src="advajax.1.1.js"></script>
       <style type="text/css">
       #pole1 {
        border: 1px outset black;
        width: 250px;
        height: 100px;
       }
       </style>
       </head>
       <body>
       <a href="javascript:loadPage('pole1.xml','pole1','pole1')">Ładuj</a>
       <div id="pole1">&nbsp;</div>
       </body>
       </html>

advajax.1.1.js
Kod
(pobież: http://advajax.anakin.us/advajax.js)

ajax.action.js
Kod
     var _preview = new Objec();
    
     function $(id) { return document.getElementById(id); }
    
     function loadPage(url, htmlTag, xmlTag) {
        _preview = $(htmlTag);
        advAJAX.get({
                         url: url,
           onInitialization : function() { _preview.innerHTML = 'Pobieram dane ...'; _preview.disabled = true; },
                  onSuccess : function(obj) { loadContents(obj.responseXML, xmlTag); },
                    onError : function(obj) { _preview.innerHTML = 'Error: ' + obj.status; },
             onFinalization : function() { _preview.disabled = false; }
        });
     }
    
     function loadContents(xmlDoc, xmlTag) {
        var rootNode = xmlDoc.getElementsByTagName(xmlTag).item(0);
        _preview.innerHTML = rootNode.firstChild.data;
     }



Ten post edytował _VBService_ 12.10.2008, 18:55:03
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 24.08.2025 - 15:27