Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

AJAX basierter Chat läuft nur im Firefox

Frage Entwicklung

Mitglied: Alex4284

Alex4284 (Level 1) - Jetzt verbinden

30.12.2009, aktualisiert 31.12.2009, 2993 Aufrufe, 2 Kommentare

Hallo.

Ich habe es nun endlich geschafft, einen Chat mit Hilfe von AJAX zu Programmieren.
Leider läuft dieser nur im Firefox.

Vielleicht ist ja der ein oder andere JavaScript Experte unter euch, der mir den ein oder
anderen Tipp geben kann, wie ich den Cht auch in anderen Browsern (v.a. IE!) zum
laufen bekomme.

Was haltete ihr generell von meinem Script bezüglich Performance? Ich denke da vor allem
an das Problem, dass immer alle Einträge neu vom Server generiert werden und dann
im Sekundentakt an die User ausgeliefert werden... ...was könnte ich da verbessern?

Freue mich auf eure Antworten!

01.
  
02.
 
03.
<script type="text/javascript"> 
04.
  
05.
	if (window.XMLHttpRequest)  
06.
07.
		xmlObject = new XMLHttpRequest(); // Mozilla, Safari, Opera 
08.
	}  
09.
	else if (window.ActiveXObject)  
10.
11.
		try  
12.
13.
			xmlObject = new ActiveXObject('Msxml2.XMLHTTP'); // IE 5 
14.
		}  
15.
		catch (e)  
16.
17.
			try  
18.
19.
				xmlObject = new ActiveXObject('Microsoft.XMLHTTP'); // IE 6 
20.
			}  
21.
			catch (e)  
22.
23.
				// 
24.
25.
26.
27.
  
28.
  
29.
  
30.
		function loadContent() 
31.
32.
			xmlObject.open('get','getdata.php'); 
33.
			xmlObject.onreadystatechange = genOutput; 
34.
			xmlObject.send(null); 
35.
36.
		 
37.
		function genOutput() 
38.
39.
			if(xmlObject.readyState == 4) 
40.
41.
				if (xmlObject.status == 200)  
42.
43.
					document.getElementById('Content').innerHTML = xmlObject.responseText; 
44.
45.
46.
		}		 
47.
  
48.
		 
49.
		function sendMessage() 
50.
51.
			var username = document.chat.username.value; 
52.
			var message = document.chat.message.value; 
53.
			 
54.
			xmlObject.open('post', 'create_message.php');   
55.
			xmlObject.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); 
56.
			xmlObject.onreadystatechange = interpretRequest; 
57.
			xmlObject.send("username="+escape(username)+"&message="+escape(message)); 
58.
  
59.
60.
		 
61.
		 
62.
  
63.
		function interpretRequest()  
64.
65.
				if (xmlObject.status != 200)  
66.
67.
					alert("Fehler bei der Übermittlung"); 
68.
				}  
69.
				loadContent(); 
70.
71.
  
72.
  
73.
	setInterval('loadContent()', 1000) 
74.
  
75.
	</script> 
76.
 
77.
 
Mitglied: Supermax
31.12.2009 um 07:48 Uhr
Statt das AJAX-Rad neu zu erfinden, solltest du vielleicht ein JavaScript-Framework wie jQuery nutzen, das u.a. komfortabel zu nutzende AJAX-Funktionen bereitstellt, ohne daß du dich selbst um Cross-Browser-Kompatibilität kümmern mußt.

Statt immer die kompletten Daten neu zu übertragen, kannst du ja mit dem Request den Timestamp oder irgendeine Form von ID der zuletzt empfangenen Nachricht mit übergeben, sodaß immer nur die neuen Einträge übertragen werden. Statt die innerHTML-Eigenschaft direkt zu setzen, kannst du stattdessen z.B. ein <div> mit dem neuen Inhalt in das Elternobjekt einhängen, wenn du diesen DIVs entsprechende IDs zuweist, kannst du dann auch alte Einträge automatisch entfernen, sodaß der angezeigte Text nicht unendlich wächst, sondern stets z.B: nur die letzten 30 Minuten Konversation angezeigt werden.
Bitte warten ..
Mitglied: Alex4284
31.12.2009 um 10:57 Uhr
Hallo Supermax!

Hab mir Deine Tipps zu Herzen genommen und ein neues Script mit dem FW jQuery erstellt.

Und es funktioniert doch glatt (in allen Browsern ) ... Vielen Dank für die Idee mit jQuery
Jetzt werden auch nicht alle Nachrichten aufgerufen und nachgeladen

Danke nochmals!


Alex
Bitte warten ..
Neuester Wissensbeitrag
Internet

Unbemerkt - Telekom Netzumschaltung! - BNG - Broadband Network Gateway

(3)

Erfahrungsbericht von ashnod zum Thema Internet ...

Ähnliche Inhalte
Webbrowser
gelöst Firefox 50 downloads stocken ohne Internet Verbindung (2)

Frage von LordXearo zum Thema Webbrowser ...

Webbrowser
Zero-Day-Lücke in Firefox bedroht Tor-Anwender (1)

Link von runasservice zum Thema Webbrowser ...

Informationsdienste
gelöst Aktuelle Firefox MSI Datei!? (8)

Frage von Hendrik2586 zum Thema Informationsdienste ...

Batch & Shell
Powershell CHAT Skript (5)

Frage von xpxy15 zum Thema Batch & Shell ...

Heiß diskutierte Inhalte
Windows Server
Outlook Verbindungsversuch mit Exchange (15)

Frage von xbast1x zum Thema Windows Server ...

Microsoft Office
Keine Updates für Office 2016 (12)

Frage von Motte990 zum Thema Microsoft Office ...

Grafikkarten & Monitore
Tonprobleme bei Fernseher mit angeschlossenem Laptop über HDMI (11)

Frage von Y3shix zum Thema Grafikkarten & Monitore ...