«
JavaScript事件驱动及事件处理

时间:2008-5-31    作者:Deri    分类: 分享


   <p>  1、基本概念</p><p>  JavaScript是基于对象(object-based)的语言。这与Java不同,Java是面向对象的语言。而基于对象的基本特征,就是采用事件驱动(event-driven)。它是在用图形界面的环境下,使得一切输入变化简单化。通常鼠标或热键的动作我们称之为事件(Event),而由鼠标或热键引发的一连串程序的动作,称之为事件驱动(Event Driver)。而对事件进行处理程序或函数,我们称之为事件处理程序(Event Handler)。</p><p>  2、事件处理程序</p><p>  在JavaScript中对象事件的处理通常由函数(Function)担任。其基本格式与函数全部一样,可以将前面所介绍的所有函数作为事件处理程序。格式如下:</p><p>  Function 事件处理名(参数表){</p><p>  事件处理语句集;</p><p>  ……</p><p>  }</p><p>  3、事件驱动</p><p>  JavaScript事件驱动中的事件是通过鼠标或热键的动作引发的。它主要有以下几个事件:</p><p>  (1)单击事件onClick</p><p>  当用户单击鼠标按钮时,产生onClick事件。同时onClick指定的事件处理程序或代码将被调用执行。通常在下列基本对象中产生:</p><p>  button(按钮对象)</p><p>  checkbox(复选框)或(检查列表框)</p><p>  radio (单选钮)</p><p>  reset buttons(重要按钮)</p><p>  submit buttons(提交按钮)</p><p>  例如可通过下列按钮激活change()文件:</p><p>  <code><Form><br /><Input type="button" Value=“ ” onClick="change()"><br /></Form></code></p><p>  在onClick等号后,可以使用自己编写的函数作为事件处理程序,也可以使用JavaScript中内部的函数。还可以直接使用JavaScript的代码等。例:</p><p>  <Input type="button" value=" " onclick=alert("这是一个例子");</p><p>  (2)onChange改变事件</p><p>  当利用text或texturea元素输入字符值改变时发该事件,同时当在select表格项中一个选项状态改变后也会引发该事件。例:</p><p>  <code><Form><br /><Input type="text" name="Test" value="Test"
              onCharge="check('this.test)"><br /></Form></code></p><p>  (3)选中事件onSelect</p><p>  当Text或Textarea对象中的文字被加亮后,引发该事件。</p><p>  (4)获得焦点事件onFocus</p><p>  当用户单击Text或textarea以及select对象时,产生该事件。此时该对象成为前台对象。</p><p>  (5)失去焦点onBlur</p><p>  当text对象或textarea对象以及select对象不再拥有焦点、而退到后台时,引发该文件,他与onFocas事件是一个对应的关系。</p><p>  (6)载入文件onLoad</p><p>  当文档载入时,产生该事件。onLoad一个作用就是在首次载入一个文档时检测cookie的值,并用一个变量为其赋值,使它可以被源代码使用。</p><p>  (7)卸载文件onUnload</p><p>  当Web页面退出时引发onUnload事件,并可更新Cookie的状态。 </p><p>  ceshicx.htm</p><p>  <code><html><br /><head><br /><title>一个JavaScript的测试程序</title><br /><script language="JavaScript"><br /><!--<br />function kkk(){<br />do{<br />username=prompt("请问您是何方神圣,报上名来","");<br />}while(username=="")<br />document.write(username,",久仰大名,请多多关照!");<br />}<br />//--><br /></script><br /></head><br /><body><br /><INPUT type="button" value="你敢碰我吗?"name=button1 onClick="kkk()"><br /></body><br /></html></code> </p><img src="/content/uploadfile/200805/2008053117260554.jpg" onclick="get_larger(this)" /><p>  图3-4 出始窗口 </p>
                <p>  说明:这个HTML页的起始页如图3-4所示,上面只有一个元素,即一个按钮。如果不设置任何事件,但单击该 按钮后不会有任何反应。但现在,定义了单击按钮的onClick事件,并把事件交给了脚本程序KKK()处 理。着是实现交互的第一步。接着,用户单击按钮后,浏览器中将出现一个如图3-5所示JavaScript的对话框,框中提示用户输入姓名。这时,只要输入姓名并且单击“确定”按钮,就可以看到浏览器的显 示结果如图3-6所示。 </p>
                <img src="/content/uploadfile/200805/2008053117260604.jpg" onclick="get_larger(this)" /><p>  图3-5 提示窗口 </p><img src="/content/uploadfile/200805/2008053117260779.jpg" onclick="get_larger(this)" />