中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > form的submit方法和submit事件
Javascript利用閉包循環(huán)綁定事件 回到列表 理解"漸進(jìn)增強(qiáng)"
 form的submit方法和submit事件

作者:大米 時(shí)間: 2008-10-14 文檔類型:轉(zhuǎn)載 來自:口碑網(wǎng)UED Team

一、問題描述

當(dāng)用JS調(diào)用form的方法submit直接提交form的時(shí)候,submit事件不響應(yīng)。為什么?知道的請回復(fù)。類比一下,我用input.select()做了測試,卻能響應(yīng)select事件。這個(gè)原因先放一邊,我們看看先怎么把眼下的問題解決了。
不響應(yīng)事件的代碼示例:

<form id="form1" action="http://www.koubei.com"></form>
<script type="text/javascript">
 var form = document.getElementById('form1');
 form.onsubmit = function() {
  alert(1);
 };
 form.submit();
</script>

實(shí)際運(yùn)行,不會有alert出來。
雖然用submit方法來提交表單有違Unobtrustive Javascript的原則,但有時(shí)候不得不用,比如做搜索提示(auto-complete)選中Item之后就需要用JS來提交搜索表單。

二、問題分析

既然本身不響應(yīng)事件,那只有手工觸發(fā)這些事件了,確定手工觸發(fā)方案之前先回顧一下事件的注冊方式:
“原始”的注冊方式有兩種,看代碼示例:

<form id="form1" action="http://www.koubei.com" onsubmit="alert(1)"></form><form id="form1" action="http://www.koubei.com"></form>
<script type="text/javascript">
document.getElementById('form1').onsubmit = function() {
 alert(1);
}
</script>

這樣的注冊事件,會給form增加了一個(gè)方法onsubmit。所以,可以通過直接執(zhí)行這個(gè)方法,等同于手工觸發(fā)了事件。
看代碼示例:

<script type="text/javascript">
 form.onsubmit();
</script>

這樣可以得到一個(gè)alert。

但是在如今“先進(jìn)”的DOM2標(biāo)準(zhǔn)注冊方式以及IE的注冊方式attachEvent已經(jīng)很常用。這些注冊方式,onsubmit方法是不存在的,如果使用form.onsubmit()會直接報(bào)錯(cuò)。

三、解決方案

當(dāng)然“先進(jìn)”的注冊方式本身也提供了手工觸發(fā)事件的解決方案,只是要針對DOM2標(biāo)準(zhǔn)和IE寫不同的程序,另外這個(gè)程序,對“原始”的注冊方式也一樣有效。請看代碼示例:

<script type="text/javascript">
 //IE fire event
 if (form.fireEvent) {
  form.fireEvent('onsubmit');
  form.submit();
 //DOM2 fire event
 } else if (document.createEvent) {
  var ev = document.createEvent('HTMLEvents');
  ev.initEvent('submit', false, true);
  form.dispatchEvent(ev);
 }
</script>

四、代碼總結(jié)

這里不再對各細(xì)節(jié)方法做說明,不熟悉的朋友請自行查閱相關(guān)資料。我們把整個(gè)代碼串起來:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=GBK">
 <title>submit</title>
 <script type="text/javascript" src="http://k.kbcdn.com/js/yui/build/utilities/utilities.js"></script>
</head>
<body>
 <form id="form1" action="http://www.koubei.com"></form>
 <script type="text/javascript">
  var form = document.getElementById('form1');
  //YUI register event
  YAHOO.util.Event.on('form1', 'submit', function() {
   alert('yui');
  });
  //DOM0 register event
  form.onsubmit = function() {
   alert(1);
  };
  //DOM2 register event
  if (form.addEventListener) {
   form.addEventListener('submit', function() {
    alert(2);
   }, false);
  //IE register event
  } else if (form.attachEvent) {
   form.attachEvent('onsubmit', function() {
    alert(2);
   });
  }

  //IE fire event
  if (form.fireEvent) {
   form.fireEvent('onsubmit');
   form.submit();
  //DOM2 fire event
  } else if (document.createEvent) {
   var ev = document.createEvent('HTMLEvents');
   ev.initEvent('submit', false, true);
   form.dispatchEvent(ev);
  }
 </script>
</body>
</html>

整個(gè)跑下來有個(gè)小問題,F(xiàn)X下,不需要form.submit(),直接把表單給提交出去了,所以這句也省掉了,原因知道的請回復(fù)。

這個(gè)demo在IE6/IE7/FX下測試通過。

本文鏈接:http://www.95time.cn/tech/web/2008/6231.asp 

出處:口碑網(wǎng)UED Team
責(zé)任編輯:bluehearts

◎進(jìn)入論壇網(wǎng)頁制作、WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論

相關(guān)文章 更多相關(guān)鏈接
Javascript利用閉包循環(huán)綁定事件
Javascript——淺析注冊事件
我的頁面制作方法
理解JavaScript中的事件
讓FF和IE離得更近
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計(jì)比賽 網(wǎng)頁制作 web標(biāo)準(zhǔn) 用戶體驗(yàn) UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點(diǎn)最新 站點(diǎn)最新列表
周大!熬•自然”設(shè)計(jì)大賽開啟
國際體驗(yàn)設(shè)計(jì)大會7月將在京舉行
中國國防科技信息中心標(biāo)志征集
云計(jì)算如何讓安全問題可控
云計(jì)算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機(jī)會
阿里行云
云手機(jī)年終巨獻(xiàn),送禮標(biāo)配299起
阿里巴巴CTO王堅(jiān)的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機(jī)主題設(shè)計(jì)大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個(gè)可愛的鉛筆圖標(biāo)
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機(jī)制之一:普通流
25個(gè)最佳最閃亮的Eclipse開發(fā)項(xiàng)目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

藍(lán)色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨(dú)家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點(diǎn)的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準(zhǔn)打上各自站點(diǎn)的水印,亦不能抹去我站點(diǎn)水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計(jì)作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯(cuò)誤,請用報(bào)告錯(cuò)誤,以利文檔及時(shí)修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報(bào)告管理員,以利管理員及時(shí)刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項(xiàng)有關(guān)法律法規(guī)
·承擔(dān)一切因您的行為而直接或間接導(dǎo)致的民事或刑事法律責(zé)任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報(bào)告錯(cuò)誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計(jì)之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計(jì)》
犀利開發(fā)—jQuery內(nèi)核詳解與實(shí)踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2