2009-05-06 7 views

Odpowiedz

0

Co powiesz na przekazanie argumentu?

foo(id); 
11
<a onclick="foo(this)" href="bar.html">Link</a> 

Następnie JavaScript byłoby:

function foo(ob) { 
    alert(ob.href); //or whatever you want to happen preferably pass an id 
} 

pomocą "to" selektor jeśli chcesz przekazać sam obiekt do funkcji.

1

Można by przekazać wartość atrybutu do funkcji href kiedy to się nazywa:

<a href="http://www.example.com" onclick="foo(this.href)">link</a> 
20

Gdy przeglądarka wywołuje funkcję jako skutek zdarzenia DOM, JavaScript przekazuje obiekt do tej funkcji, która zawiera informacje o wydarzeniu. Ale działa to trochę inaczej w IE niż inne. Aby działać we wszystkich przeglądarkach, foo() powinien podjąć argumentu * (używam e):

function foo(e) { 
    var sender = (e && e.target) || (window.event && window.event.srcElement); 
    //sender is the DOM element which was clicked 
    alert(sender.href); //assumes the clicked element was an <a> 
} 

Pierwsza linia przypisze „Nadawca” wartość elementu, który pochodzi zdarzenie we wszystkich przeglądarkach.

Teraz, jeśli <a>zawiera elementów podrzędnych (na przykład obraz) i jeden z tych była rzeczywista elementu kliknął, to staną się elementem „nadawca”. Jeśli jest to możliwe, trzeba chodzić DOM od nadawcy aż znajdziesz swój link:

function foo(e) { 
    var sender = (e && e.target) || (window.event && window.event.srcElement); 
    //sender is the DOM element which was clicked 

    var myEle = sender; 

    //find the parent node until we hit the <a> 
    while(myEle.tagName.toUpperCase() != 'A') { 
    myEle = myEle.parentNode; 
    } 

    //myEle is now the <a>. sender is still the originator. 
    alert(myEle.href); 
} 

* Można także uzyskać dostęp do argumentów przekazywanych do funkcji, nawet jeśli nie zostały one uznane, za pomocą tablica arguments[].

+1

lubię zwarcie nad tirnary czasami sobie ... var nadawcy = (window.event && window.event.srcElement) || mi.cel; – Tracker1

+0

@cresentfresh onclick jest semantycznie niepoprawny i niezwykle nieelastyczny. Zobacz techniki progresywnego ulepszania. –

2

Konwencja o to, że to odnosi się do elementu DOM, który program obsługi jest wywoływana na. Więc jeśli chcesz wiedzieć href linku:

function foo() { 
    // Inside foo this will refer to the DOM element if called as an event handler 
    var href = this.href 
} 

To powinno załatwić sprawę.

EDIT: Jeśli foo jest wywoływana z onclick-przewodnika wprost w DOM, tj

<a [...] onclick="foo()"> 

wówczas oryginalny kontekst to zostaną utracone wewnątrz foo. Aby rozwiązać ten jeden może wiązać wywołanie funkcji do oryginalnego kontekstu:

<a [...] onclick="foo.call(this)"> 
+0

Nie.