| HTML, JavaScript, AJAX und CSS Probleme mit HTML? Netscape oder IE funktionieren nicht so, wie sie sollen? Stellt eure HTML-Fragen hier im Forum und diskutiert eure Probleme mit anderen Entwicklern. |
 |
|

15-06-2009, 20:54
|
Kropff
  Administrator
|
|
Registriert seit: Mar 2002
Ort: Köln
Beiträge: 11.305
|
|
setTimeout in Objekten
Manchmal treibt mich diese Sprache einfach in den Wahnsinn. Also das hier funktioniert reibungslos:
PHP-Code:
function bla()
{
function blubb()
{
blubber();
}
function blubber()
{
...
}
}
aber hier bekomme ich die Meldung, dass blubber nicht definiert ist:
PHP-Code:
function bla()
{
function blubb()
{
window.setTimeout('blubber()', 2000);
}
function blubber()
{
...
}
}
Ist das wieder eine dieser Seltsamkeiten bei JavaScript oder habe ich etwas übersehen?
Peter
__________________
Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
Meine Seite
|

15-06-2009, 20:59
|
unset
 Moderator
|
|
Registriert seit: Jan 2007
Ort: Düsseldorf
Beiträge: 3.778
|
|
Zitat:
Zitat von Kropff
Manchmal treibt mich diese Sprache einfach in den Wahnsinn. Also das hier funktioniert reibungslos:
PHP-Code:
function bla()
{
function blubb()
{
blubber();
}
function blubber()
{
...
}
}
aber hier bekomme ich die Meldung, dass blubber nicht definiert ist:
PHP-Code:
function bla()
{
function blubb()
{
window.setTimeout('blubber()', 2000);
}
function blubber()
{
...
}
}
Ist das wieder eine dieser Seltsamkeiten bei JavaScript oder habe ich etwas übersehen?
Peter
|
ich tippe ungetestet auf
Code:
window.setTimeout('bla.blubber()', 2000);
|

15-06-2009, 21:07
|
Kropff
  Administrator
|
|
Registriert seit: Mar 2002
Ort: Köln
Beiträge: 11.305
|
|
Zitat:
Zitat von unset
ich tippe ungetestet auf
Code:
window.setTimeout('bla.blubber()', 2000);
|
Nee, hab ich schon probiert. Die selbe Meldung "blubber" ist not a function". Auch ein this.blubber bringt nichts.
peter
__________________
Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
Meine Seite
|

15-06-2009, 21:13
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.324
|
|
Zitat:
Zitat von Kropff
Nee, hab ich schon probiert. Die selbe Meldung "blubber" ist not a function". Auch ein this.blubber bringt nichts. 
|
Das Objekt "bla" muss natürlich vorher instanziert werden.
PHP-Code:
function bla()
{
function blubb()
{
window.setTimeout('foobar.blubber()', 2000);
}
function blubber()
{
...
}
}
var foobar = new bla();
|

15-06-2009, 21:42
|
Kropff
  Administrator
|
|
Registriert seit: Mar 2002
Ort: Köln
Beiträge: 11.305
|
|
Zitat:
Zitat von h3ll
Das Objekt "bla" muss natürlich vorher instanziert werden.
|
Ist natürlich schon geschehen. Die "private" Methode blubb wird z.B. über eine "öffentliche" aufgerufen. Das sieht dann vom Prinzip her so aus:
PHP-Code:
function bla()
{
this.jodelbla = function ()
{
blubb();
}
function blubb()
{
// funzt nicht
setTimeout('this.blubber()', 1000);
// auch nicht
setTimeout('blubber()', 1000);
// das eh nicht
setTimeout('laber.blubber()', 1000);
}
function blubber()
{
alert ('hallo');
}
}
window.onload = function ()
{
var laber = new bla();
laber.jodelbla();
}
Außerdem weiß das Objekt bla doch nichts von der Referenz laber. So kann/sollte das doch nicht funktionieren.
Peter
__________________
Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
Meine Seite
|

15-06-2009, 21:53
|
|
Hopka
PHP Expert
|
|
Registriert seit: May 2003
Ort: Köln
Beiträge: 2.172
|
|
Wenn du das in Anführungszeichen setzt, hat es den gleichen Effekt wie eval.
PHP-Code:
window.setTimeout(this.blubber, 2000);
Aber Vorsicht: Wenn ich mich jetzt nicht irre, zeigt this dann innerhalb der Funktion blubber auf das Window-Objekt, weil du quasi die Funktion an sich (=das Funktionsobjekt) übergibst.
|

15-06-2009, 21:55
|
|
PHP-Desaster
PHP Expert
|
|
Registriert seit: Mar 2006
Beiträge: 3.104
|
|
setTimeout läuft doch im globalen Scope, da ist nix mit Zugriff auf die Funktion. Allerdings akzeptiert setTimeout auch eine Funktion anstelle einer Zeichenkette. Lösung ist also:
PHP-Code:
function bla() {
this.blubb=function(){
window.setTimeout(blubber, 2000);
}
function blubber(){
alert('blubber');
}
}
var b=new bla()
b.blubb()
|

15-06-2009, 22:15
|
Kropff
  Administrator
|
|
Registriert seit: Mar 2002
Ort: Köln
Beiträge: 11.305
|
|
Also folgender Code läuft bei mir. Es gibt zwar noch eine Meldung à la "useless setTimeout call (missing quotes around argument?)" aber es funktioniert.
PHP-Code:
function bla()
{
this.jodelbla = function ()
{
blubb();
}
function blubb()
{
setTimeout(blubber(), 1);
}
function blubber ()
{
alert ('hallo');
}
}
window.onload = function ()
{
var laber = new bla();
laber.jodelbla();
}
Warum es bei meiner Programmierung noch nicht klappt, kann ich derzeit nicht sagen. Sobald ich die Infos dazu habe, melde ich mich.
Danke an alle
Peter
__________________
Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
Meine Seite
|

15-06-2009, 22:36
|
|
PHP-Desaster
PHP Expert
|
|
Registriert seit: Mar 2006
Beiträge: 3.104
|
|
Kropff, das ist doch Blödsinn. Überleg dir nochmal gut, was folgender Codeabschnitt macht
PHP-Code:
setTimeout(blubber(), 1);
Richtig, die Funktion ausführen und den Rückgabewert an setTimeout übergeben  Das "funktioniert" kommt dir nur so vor, da dieser Aufruf bestimmt auch nur gefühlte 1ms benötigt. Und die Warnung ist natürlich vollkommen korrekt, der Aufruf macht so keinen Sinn.
|

15-06-2009, 22:44
|
Kropff
  Administrator
|
|
Registriert seit: Mar 2002
Ort: Köln
Beiträge: 11.305
|
|
Zitat:
Zitat von PHP-Desaster
Richtig, die Funktion ausführen und den Rückgabewert an setTimeout übergeben  Das "funktioniert" kommt dir nur so vor, da dieser Aufruf bestimmt auch nur gefühlte 1ms benötigt. Und die Warnung ist natürlich vollkommen korrekt, der Aufruf macht so keinen Sinn.
|
Es ist spät, ich bin alt und brauche meine Ruhe. Schaue mir das morgen Abend noch mal genau an. Man sollte halt nicht nach 20Uhr noch wie ein Bekloppter JavaScript programmieren. Das kann nicht gut gehen  . Außerdem ist SelfHTML in der Beziehung keine gute Wahl. Und das JavaScript-Handbuch leider auch nicht. Außerdem habe ich ehrlich gesagt noch nie mit setTimeout in Objekten gearbeitet. Ist für mich also Neuland.
Peter
PS: Und zusätzlich muss ich gerade meinen Auftritt gegen "Pornoattacken" absichern. Ist ein ein wenig zu viel auf einmal.
__________________
Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
Meine Seite
Geändert von Kropff (15-06-2009 um 22:48 Uhr)
|

15-06-2009, 23:01
|
wahsaga
 Moderator
|
|
Registriert seit: Sep 2001
Beiträge: 24.481
|
|
Code:
function bla() {
var thisInstance = this;
function blubb() {
window.setTimeout(thisInstance.blubber, 2000);
}
function blubber() {
...
}
}
Zitat:
|
Zitat von hopka
Aber Vorsicht: Wenn ich mich jetzt nicht irre, zeigt this dann innerhalb der Funktion blubber auf das Window-Objekt, weil du quasi die Funktion an sich (=das Funktionsobjekt) übergibst.
|
Auch das lässt sich mit Closures vermeiden.
SELFHTML Artikel: Organisation von JavaScripten
__________________
I don't believe in rebirth. Actually, I never did in my whole lives.
|

15-06-2009, 23:06
|
|
h3ll
Registrierter Benutzer
|
|
Registriert seit: Mar 2008
Beiträge: 2.324
|
|
Zitat:
Zitat von wahsaga
|
JavaScript ist einfach nur abartig.
|

15-06-2009, 23:25
|
Kropff
  Administrator
|
|
Registriert seit: Mar 2002
Ort: Köln
Beiträge: 11.305
|
|
Zitat:
Zitat von h3ll
JavaScript ist einfach nur abartig.
|
Sag ich doch  . Vor Allem abends nach der Arbeit, wenn die Konzentration nachlässt.
Peter
__________________
Nukular, das Wort ist N-u-k-u-l-a-r (Homer Simpson)
Meine Seite
|

16-06-2009, 08:50
|
 |
CiaoSen
  Administrator
|
|
Registriert seit: May 2009
Beiträge: 30
|
|
versuch mal folgendes:
window.setTimeout(function(){ blubber();}, 2000);
klappt bei sowas "fast" immer
mfg jura
|

16-06-2009, 10:19
|
|
jmc
PHP Junior
|
|
Registriert seit: Mar 2006
Beiträge: 868
|
|
Für die Übergabe des Scopes kannst du auch sowas benutzen (auch in vielen Javascript Frameworks angewandte Methode):
Code:
Function.prototype.scope = function(){
var instance = this, length = arguments.length, args = new Array(), object;
while(length--){
args[length] = arguments[length];
}
object = args.shift();
return function(){
return instance.apply(object, args);
}
}
function bla(){
this.a = "Test";
function blub(){alert(this.a);}
this.blo = function(){
setTimeout(blub.scope(this), 1000);
}
}
blob = new bla;
blob.a = "It works";
blob.blo();
|
|
Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
|
|
|
Ähnliche Themen
|
| Thema |
Autor |
Forum |
Antworten |
Letzter Beitrag |
|
setTimeout mit Klassenmethoden aufrufen?
|
Jesseblue |
HTML, JavaScript, AJAX und CSS |
3 |
19-06-2006 12:32 |
|
Verständnisproblem setTimeout()
|
flyingMiATA |
HTML, JavaScript, AJAX und CSS |
0 |
25-11-2005 14:40 |
|
Abbrechen von setTimeout
|
zimmbi |
HTML, JavaScript, AJAX und CSS |
0 |
21-10-2005 15:07 |
|
for-Schleife und setTimeout
|
Wantonio |
HTML, JavaScript, AJAX und CSS |
1 |
03-03-2005 17:17 |
|
setTimeout und pfad
|
frank7l7 |
HTML, JavaScript, AJAX und CSS |
5 |
02-02-2004 15:11 |
| Themen-Optionen |
|
|
| Thema bewerten |
|
|
Forumregeln
|
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre Beiträge zu bearbeiten.
HTML-Code ist aus.
|
|
|
|
PHP News
|