Heim >Web-Frontend >js-Tutorial >Bauen Sie einen Ajax -Baum mit Yui
Ich habe die URLs aus dem obigen Codebeispiel ausgelassen, da sie extrem lang sind, und es ist am besten, Ihre eigene URL mit der Funktionalität zu konstruieren, die Sie benötigen. Der Vorteil davon ist, dass Sie problemlos alle anderen YUI -Komponenten einfügen können, die Sie benötigen, ohne zusätzliche Stilblätter oder Skriptdateien hinzuzufügen. Gehen Sie einfach zur Konfigurations -App zurück und generieren Sie einen neuen Satz von Links! Zunächst enthält es nur einen Textknoten, der das Etikett „Apple“ enthält. Wenn der Benutzer auf diesen Knoten klickt, erstellt unser Code einen Unterbaum darunter und füllt ihn mit Synonymen für „Apple“ aus. Wir erstellen den Baum mit dem Konstruktor des Treeview, dessen Argument das HTML -Element ist, in dem wir den Baum bauen (ajaxTeediv). Der GetRoot -Anruf empfängt einen Verweis auf die Wurzel des Baumes und gibt ihn an den Konstruktor des TextNode weiter. Das Angeben der Wurzel dem neuen Knoten verbindet den Baum; Es erstellt einen Link zurück zum Elternteil. Wir machen die tatsächliche Zeichnung des Baumes mit seiner Render -Methode.
Wir beginnen damit, einige Variablen zu deklarieren. Obnode wird das Knotenobjekt sein, Obajaxtree wird das Baumobjekt sein, und Treeroot wird verwendet, um einen Hinweis auf den Wurzelknoten des Baumes zu halten. die meiste unserer Aufmerksamkeit. Die SetDyNamicload -Methode gibt dem Baum mit, dass wir wissen möchten, wann der Benutzer auf einen seiner Knoten klickt, um ihn zu erweitern, und er sagt dem Baum, welche Funktion zu rufen (Makemorenoden, die wir in Kürze schreiben werden), wenn diese Klicks passieren:
Nachdem wir diese Option festgelegt haben, speichern wir eine Referenz auf die Treeroot und eine neue Textnode. Das Übergeben der Treeroot -Variablen an den TextNode -Konstruktor verbindet den Knoten mit dem Baum. Schließlich rufen wir die Render -Methode auf, um den Baum anzuzeigen. Hier ist die Anweisung, die sie nennt:
Dies ist die erste Anweisung unseres Code, die ausgeführt wird. Die OnDomready -Methode ruft BuildaJaxTree auf, wenn die HTML -Seite voll geladen ist. Das Ausführen unseres Skripts vor diesem Punkt würde Fehler einladen.
Lassen Sie uns jetzt durch die Funktion makemorenoden gehen. Weitere Informationen finden Sie auf den Überblick über das zu Beginn dieses Artikels beschriebene Rückrufobjekt. Denken Sie daran, dass unser AJAX -Anruf (asyncrequest) ein Rückrufobjekt mit Erfolgs- und Misserfolgsmethoden benötigt, sodass er eine dieser Methoden nach der Mission zur Datenerfassung aufrufen kann. Der größte Teil des Codes in Makemorenodes erstellt dieses Callback -Objekt.
Hier ist das Rückrufobjekt, das wir verwenden werden. Vergleichen Sie es mit dem generischen Rückrufobjekt, das wir bei der Einführung von Asyncrequest gesehen haben:
function buildAjaxTree() { var obNode; var obAjaxTree; var treeRoot; obAjaxTree = new YAHOO.widget.TreeView ("AjaxTreeDiv"); <em>obAjaxTree.setDynamicLoad(makeMoreNodes,0);</em> treeRoot = obAjaxTree.getRoot(); obNode = new YAHOO.widget.TextNode("apple", treeRoot, false); obAjaxTree.render();}
Die Erfolgs- und Fehlereigenschaften beziehen sich auf die Methoden, die Asyncrequest aufruft, nachdem es unser serverseitiges Thesaurus-Skript abfragt. Wir werden die Funktion der FoundSyNonyms aufrufen, wenn es dem PHP -Skript gelingt, einige Synonyme oder den Condnosynonyme -Rückruf einzuziehen, wenn das PHP -Skript bei seiner Suche fehlschlägt. Beachten Sie, dass die Timeout -Eigenschaft in diesem Fehlerfall ein Faktor ist: AsyncRequest Flags Ein Fehler, wenn sie nicht innerhalb von sieben Sekunden (7.000 Millisekunden) aufgerufen wird. Denken Sie daran, dass die Argumenteigenschaft alle Daten enthält, die durch die von Asyncrequest bezeichneten Erfolgs- und Misserfolgsfunktionen benötigt werden. Für unser Beispiel speichern wir vor dem Ajax -Anruf den Knoten, der vom Benutzer im Argument geklickt hat. Die Erfolgsmethode benötigt diesen Knoten aus zwei Gründen. Erstens wird ein neuer Synonym -Subtree erstellt: Ein Stammknoten wird dafür benötigt, und der vom Benutzer geklickte Knoten wird dieses Root sein. Zweitens, um den Knoten mitzuteilen, dass wir mit ihm mit ihm fertig sind, über seine LOADComplete -Methode. Wenn wir diese Methode nicht abgefeuert haben, würde der Baum einfrieren, da einer seiner Knoten nicht weiß, wann das Hören auf die Mausklicks des Benutzers wieder aufgenommen werden soll. Auch wenn die Fehlermethode dem Baum keine Knoten hinzufügt, benötigt der Knoten, auf den der Benutzer geklickt hat
Das obige ist der detaillierte Inhalt vonBauen Sie einen Ajax -Baum mit Yui. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!