儘管HTML事件屬性可以將事件處理器捆綁為文本的一部分,但其代碼一般較為短小,功能較弱,只適用於做簡單的資料驗證、返回相關提示資訊等場合。而使用JavaScript指令碼可以更為方便的處理各種事件。
由於HTML 將事件看成對象的屬性,可以通過給該屬性賦值的方式來改變事件的處理 器
1. 匿名函數
匿名函數的方式即使用Function物件建構匿名的函數,並將其方法複製給事件,此時匿名的函數成為該事件的事件處理器。
<form name=MyForm id=MyForm>
<input type="button" name="MyButton" id="MyButton" value="事件測試">
</form>
document.MyForm.MyButton.onclick = new Function()
{
alert("You Clicked me!");
}
2. 顯式聲明
設定事件處理器時,也可以不使用上面的匿名函數,而是將該事件的處理器設定為已經存在的函數。
<form name=MyForm id=MyForm>
<input type="button" name="MyButton" id="MyButton" value="事件測試">
</form>
function theFunc(){
alert("You Clicked me!");
}
document.MyForm.MyButton.onclick = theFunc;
3. 手工觸發
<form name=MyForm id=MyForm>
<input type="button" name="MyButton" id="MyButton" value="事件測試">
<input type="button" name="MyButton" id="MyButton" value="手工觸發測試" onclick="document.MyForm.MyButton.onclick()">
</form>