欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

JavaScript處理各種事件詳解

liguoquan
2023年11月18日 10:6 本文熱度 603
:Javascript處理各種事件詳解


Javascript處理各種事件詳解

圖1 大力按下電梯中的求助按鈕,維護(hù)人員就會來修理電梯

當(dāng)用戶在網(wǎng)頁上執(zhí)行移動鼠標(biāo)、點(diǎn)擊按鈕、提交表單等操作,會觸發(fā)相應(yīng)的事件,Javascript腳本可以對特定的事件進(jìn)行處理,從而實(shí)現(xiàn)與用戶的交互。

例如當(dāng)用戶點(diǎn)擊網(wǎng)頁上的按鈕,會觸發(fā)onclick事件。如圖2所示,以下代碼表明當(dāng)用戶點(diǎn)擊add按鈕,瀏覽器會執(zhí)行Javascript腳本中的add()函數(shù):

<input type="button" value="add" onclick="add()"  />

圖2 Javascript腳本的add()函數(shù)處理onclick事件

表1列出了常用的事件,對這些事件的觸發(fā)時機(jī)作了說明。這些事件可分為三類:表單相關(guān)事件、鼠標(biāo)鍵盤事件、頁面相關(guān)事件。

表1 JavaScrip腳本可以處理的事件

1. onfocus獲得焦點(diǎn)和onblur失去焦點(diǎn)事件

例程1的focus.html演示處理onfocus和onblur事件。當(dāng)焦點(diǎn)進(jìn)入網(wǎng)頁上的username文本輸入框,該輸入框的背景色變?yōu)榫G色,當(dāng)焦點(diǎn)離開,背景色改為白色。

例程1 focus.html

<form name="myform">
  username:<input type="text" name="username"                        
              onfocus="dofocus()"  onblur="doblur()" /></form><script> function dofocus(){
 // 獲得當(dāng)前的事件  var event=window.event;
 // 獲得觸發(fā)當(dāng)前事件的元素
 var element=event.srcElement;
 // 把元素的背景色改為綠色  element.style.background="#00FF00"    }function doblur(){
 // 獲得當(dāng)前的事件  var event=window.event;
 // 獲得觸發(fā)當(dāng)前事件的元素
 var element=event.srcElement;
 // 把元素的背景色改為白色  element.style.background="#FFFFFF"    }</script>

在dofocus()函數(shù)中,window.event表示當(dāng)前的onfocus事件,event.srcElement表示觸發(fā)當(dāng)前事件的username文本輸入框,element.style.background表示username文本輸入框的背景色。

在本范例中,dofocus()函數(shù)把username文本輸入框的背景色改為綠色,doblur()函數(shù)把背景色改為白色,參見圖3。

圖3 Javascript腳本會改變username文本框的背景顏色

2. onsubmit表單提交和onreset表單重置事件

當(dāng)用戶按下表單中的提交按鈕,會觸發(fā)onsubmit事件,按下重置按鈕,會觸發(fā)onreset事件。 以下輸入框的type屬性的值分別為submit和reset,分別表示提交按鈕和重置按鈕:

<input type="submit" value="submit" />  
<input type="reset" value="reset" />  

以下代碼指定dosubmit()函數(shù)處理onsubmit事件,doreset()函數(shù)處理onreset事件,action屬性指定把表單提交給后端的hello.jsp處理:

<form name="myform"
      onsubmit="return dosubmit()"
      onreset="doreset()"
      action="hello.jsp">

例程2的form.html演示了對onsubmit事件的處理過程。當(dāng)onsubmit事件觸發(fā)后,瀏覽器首先執(zhí)行dosubmit()函數(shù)。接下來,瀏覽器會根據(jù)dosubmit()函數(shù)的返回值來決定是否請求訪問后端的hello.jsp。如果該函數(shù)返回true,瀏覽器就會請求訪問hello.jsp;如果該函數(shù)返回false,則不會請求訪問hello.jsp。

例程2 form.html

<form name="myform"  action="hello.jsp"
      onsubmit="return dosubmit()" >
 username:<input type="text" name="username" />                  
 <input type="submit" value="submit" />  
 <input type="reset" value="reset" />  </form><script> function dosubmit(){
 var isSubmit=true;

 if(myform.username.value==""){
   alert("Please input username.");
   isSubmit=false;
 }  

 return isSubmit;}</script>

以上dosubmit()函數(shù)會檢查username文本輸入框,如果值為空,就提示用戶輸入username,并返回false;否則返回true。因此,只有當(dāng)username文本輸入框不為空,瀏覽器才會把表單提交給后端的hello.jsp,參見圖4。

圖4 dosubmit()函數(shù)的執(zhí)行流程

例程3是hello.jsp的代碼,它會讀取表單中的username輸入框的值,并把它輸出到網(wǎng)頁中。

例程3 hello.jsp

 <%
   // 讀取表單中的username輸入框的值    String username = request.getParameter("username");
 %>

 <h1>Hello,<%= username %></h1>

當(dāng)用戶在form.html的表單的username輸入框中輸入weiqin,hello.jsp會返回“Hello,weiqin”,參見圖5。

圖5 后端hello.jsp處理用戶提交表單的請求

3. onclick鼠標(biāo)單擊事件

當(dāng)用戶單擊網(wǎng)頁上的按鈕、圖片等元素,會觸發(fā)onclick事件。 例程4的bgcolor.html會在網(wǎng)頁上顯示一個change按鈕,點(diǎn)擊該按鈕,網(wǎng)頁的背景色會在紅色與白色之間切換。document.bgColor表示網(wǎng)頁的背景色。

例程4 bgcolor.html

<form name="myform" >
<input type="button" value="change" onclick="doclick()"  /></form><script>var isRed=true;function doclick(){  // 切換網(wǎng)頁的背景色  if(isRed)
   document.bgColor="red";
 else
   document.bgColor="white";

 isRed=!isRed;       // isRed變量的值取反}</script>

4. onmouseover鼠標(biāo)移入和onmouseout鼠標(biāo)移出事件

當(dāng)用戶在網(wǎng)頁上把鼠標(biāo)移入某個元素的區(qū)域,會觸發(fā)onmouseover事件,把鼠標(biāo)移出某個元素的區(qū)域,會觸發(fā)onmouseout事件。例程5的opacity.html演示了對這兩種事件的處理。

例程5 opacity.html

<img src="logo.gif"
     onmouseover="visible(this,1)"
     onmouseout="visible(this,0.3)"  /><script>function visible(element,n){
 // 設(shè)置圖片的透明度  element.style.opacity=n;}</script>

opacity.html會顯示一張圖片,當(dāng)鼠標(biāo)移入該圖片區(qū)域,圖片的透明度設(shè)為1,當(dāng)鼠標(biāo)移出該圖片區(qū)域,透明度設(shè)為0.3,參見圖6。visible(element,n)函數(shù)中的element參數(shù)表示鼠標(biāo)移入的元素或移出的元素,此處為圖片。參數(shù)n表示圖片的透明度。

圖6 圖片的透明度隨著鼠標(biāo)的移入和移出發(fā)生改變

5. onkeydown按鍵事件

當(dāng)用戶在網(wǎng)頁上按下鍵盤的鍵就會觸發(fā)onkeydown事件。例程6的box.html演示了對onkeydown事件的處理。

例程6 box.html

<div id="box"></div><script>// 獲取頁面中id為box的元素var box = document.getElementById("box");  box.style.position = "absolute";    // 色塊絕對定位box.style.width = "20px";            // 色塊寬度box.style.height = "20px";           // 色塊高度box.style.backgroundColor = "red";  // 色塊背景色// 指定處理onkeydown事件的函數(shù)document.onkeydown = dokeydown;// 方向鍵控制色塊移動function dokeydown(){  
 var event = window.event;  
 switch(event.keyCode){  // 獲取當(dāng)前按下鍵盤鍵的編碼    case 37 :  // 按下LEFT箭頭鍵,向左移動5個像素                box.style.left = box.offsetLeft - 5  + "px";
               break;
   case 39 :  // 按下RIGHT箭頭鍵,向右移動5個像素                box.style.left = box.offsetLeft + 5 + "px";
               break;
   case 38 :  // 按下UP箭頭鍵,向上移動5個像素                box.style.top = box.offsetTop  - 5 + "px";
               break;
   case 40 :  // 按下DOWN箭頭鍵,向下移動5個像素                box.style.top = box.offsetTop  + 5 + "px";
               break;
 }}</script>

在dokeydown()函數(shù)中,event.keyCode表示鍵的鍵碼。每個鍵都有固定的鍵碼,例如LEFT、RIGHT、UP、DOWN鍵的鍵碼分別為37、39、38、40。

box.html會在網(wǎng)頁上顯示一個紅色的色塊,當(dāng)按下鍵盤的LEFT、RIGHT、UP、DOWN鍵,色塊就會向相應(yīng)的方向移動,參見圖7。

圖7 通過鍵盤上的方向鍵來移動色塊

6. onload頁面加載和onunload頁面卸載事件

當(dāng)用戶訪問某個網(wǎng)頁,瀏覽器就會先加載該網(wǎng)頁,此時會觸發(fā)onload事件。當(dāng)用戶離開網(wǎng)頁、刷新網(wǎng)頁或關(guān)閉瀏覽器時,會觸發(fā)onunload事件。

例程7的page.html在例程-5的opacity.html的基礎(chǔ)上,增加了對onload事件的處理。當(dāng)瀏覽器加載page.html頁面時,會把頁面上圖片的透明度設(shè)為0.3。document.images[0]表示頁面上的第一個圖片。

例程7 page.html

<body onload="visible(document.images[0],0.3)"><img src="logo.gif" onmouseover="visible(this,1)"
     onmouseout="visible(this,0.3)"   /><script>function visible(element,n){
 // 設(shè)置圖片的透明度  element.style.opacity=n;}</script></body>


該文章在 2023/11/18 10:06:56 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved