Вот самый грязный путь:)
<a href=".." onclick='sayHello();alert("say hello again");sayGoodMorning()'>.</a>
Вот несколько более разумная версия.Оберните все в функцию:
<a href=".." onclick="sayItAll()">..</a>
JavaScript:
function sayItAll() {
sayHello();
alert("say hello again");
sayGoodMorning();
}
И вот правильный способ сделать это.Используйте модель регистрации событий вместо того, чтобы полагаться на атрибут или свойство onclick
.
<a id="linkId" href="...">some link</a>
JavaScript:
var link = document.getElementById("linkId");
addEvent(link, "click", sayHello);
addEvent(link, "click", function() {
alert("say hello again");
});
addEvent(link, "click", sayGoodMorning);
Дается кросс-браузерная реализация функции addEvent
ниже (из scottandrew.com ):
function addEvent(obj, evType, fn) {
if (obj.addEventListener) {
obj.addEventListener(evType, fn, false);
return true;
} else if (obj.attachEvent) {
var r = obj.attachEvent("on" + evType, fn);
return r;
} else {
alert("Handler could not be attached");
}
}
Обратите внимание, что если все 3 действия должны выполняться последовательно, вы все равно должны пойти дальше и обернуть их в одну функцию.Но этот подход все еще превосходит второй подход, хотя он кажется немного многословным.
var link = document.getElementById("linkId");
addEvent(link, "click", function() {
sayHello();
alert("say hello again");
sayGoodMorning();
});