網頁表單提交方式大全 菜鳥總結

来源:http://www.cnblogs.com/androidshouce/archive/2016/06/27/5619146.html
-Advertisement-
Play Games

大家先來看看表單提交的幾種方式: 1、<!--通用提交按鈕--> <input type="submit" value="提交"> 2、<!--自定義提交按鈕--> <button type="Submit">提交</button> 3、<!--圖像按鈕--> <input type="image" ...


大家先來看看表單提交的幾種方式:

  1、<!--通用提交按鈕-->
  <input type="submit" value="提交">
  2、<!--自定義提交按鈕-->
  <button type="Submit">提交</button>
  3、<!--圖像按鈕-->
  <input type="image" src = "btn.png">
說明:用戶提交按鈕或圖像按鈕時,就會提交表單。使用<input>或<button>都可以定義提交按鈕,只要將其特性的值設置為“submit”即可,而圖像按鈕則是通過<input>的type特性值設置為”image”來定義的。因此,只要我們單擊一下代碼生成的按鈕,就可以提交表單。

    4、阻止表單提交
只要在表單中存在上面列出的任何一種按鈕,那麼相應表單控制項擁有焦點的情況下,按回車鍵就可以提交表單。如果表單里沒有提交按鈕,按回車鍵不會提交表單。

  以這種方式提交表單時,瀏覽器會在將請求發送給伺服器之前觸發submit事件。這樣,我們就有機會驗證表單數據,並據以決定是否允許表單提交。阻止這個事件的預設行為就可以取消表單提交。例如,下麵代碼會阻止表單提交:

複製代碼
 1 var EventUtil = {
 2     addHandler: function (element, type, handler) {
 3         if (element.addEventListener) {
 4             element.addEventListener(type, handler, false);
 5         } else if (element.attachEvent) {
 6             element.attachEvent("on" + type, handler);
 7         } else {
 8             element["on" + type] = handler;
 9         }
10     },
11     getEvent: function (event) {
12         return event ? event : window.event;
13     },
14     preventDefault: function (event) {
15         if (event.preventDefault) {
16             event.preventDefault();
17         } else {
18             event.returnValue = false;
19         }
20     }
21 
22 };
23 
24 var form = document.getElementById("myForm");
25 EventUtil.addHandler(form, "submit", function () {
26     //取得事件對象
27     event = EventUtil.getEvent(event);
28     //阻止預設事件
29     EventUtil.preventDefault(event);
30 });
複製代碼

調用preventDefault()方法阻止了表單提交。一般來說,在表單數據無效而不能發送給伺服器時,可以使用這一技術。

5、在JavaScript中,以編程方式調用submit()方法也可以提交表單。
     這種方式無需表單包含提交按鈕,任何時候都可以正常提交表單。來看一個例子:

  var form = document.getElementById("myForm");
  //提交表單
  form.submit();  
     在以調用submit()方法的形式提交表單時,不會觸發submit事件,因此要記得在調用此方法之前先驗證表單數字據。

  提交表單時可能出現的最大問題,就是重覆提交表單。在第一次提交表單後,如果長時間沒有反映,用戶可能會變得不耐煩。這時候,他們也許會反覆單擊提交按鈕。結果往往很麻煩(因為伺服器要處理重覆請求),或者造成錯誤(如果是下了訂單,那麼可能會多定好幾份)。
解決這一問題的辦法有兩個:
     在第一次提交表單後就禁用提交按鈕;
     利用onsubmit事件處理程式取消後續的表單提交操作。

 

接下來將詳細介紹通過form提交的幾種方法

方法一:利用form的onsubmit()函數(經常使用),代碼如下:

複製代碼
 1 1.<script type="text/javascript">  
 2 2.    function validateForm(){   
 3 3.    if(document.reply.title.value == ""){ //通過form名來獲取form   
 4 4.        alert("please input the title!");   
 5 5.        document.reply.title.focus();   
 6 6.        return false;   
 7 7.    }      
 8 8.    if(document.forms[0].cont.value == ""){ //通過forms數組獲取form   
 9 9.        alert("please input the content!");   
10 10.        document.reply.cont.focus();   
11 11.        return false;   
12 12.    }   
13 13.    return true;   
14 14.  }   
15 15.<form name="reply"  method="post" onsubmit="return validateForm( );">  
16 16.        <input type="text" name="title"  size="80" /><br />  
17 17.        <textarea name="cont" cols="80" rows="12"></textarea><br />  
18 18.        <input type="submit" value="提交" >  
19 19.</form>  
20 20.註意:   
21 21.1.onsubmit屬性內容一定要有return關鍵字,否則函數會直接執行,不會返回   
22 22.2.validateForm一定要返回一個boolean類型的返回值   
23 23.3.提交按鈕要寫成submit類型的 
複製代碼

方法二:利用input類型為submit組件的onclick()函數

    1.將上面form標簽中的onsubmit="return validateForm()"屬性,去掉。

    2.為“提交”按鈕添加onclick事件,如下:

     <input type="submit" value="提交" onclick="return validateForm();">

方法三:利用button組件的onclick()函數,手動提交,代碼如下:

複製代碼
 1 1.<script type="text/javascript">  
 2 2.    function modifyItem() {   
 3 3.        if (trim(document.getElementById("itemName").value) == "") {   
 4 4.            alert("物料名稱不能為空!");   
 5 5.            document.getElementById("itemName").focus();   
 6 6.            return;   
 7 7.        }    
 8 8.        with (document.getElementById("itemForm")) {   
 9 9.            method = "post";   
10 10.            action = "item.do?command=modify&pageNo=${itemForm.pageNo}";   
11 11.            submit();   
12 12.        }   
13 13.    }   
14 14.    //返回   
15 15.    function goBack() {   
16 16.        window.self.location = "item.do?command=list&pageNo=${itemForm.pageNo}";   
17 17.    }   
18 18.</script>  
19 19.<form name="itemForm" id="itemForm">  
20 20.      <input name="itemNo" type="text"   id="itemNo" value="${ item.itemNo }" >  
21 21.      <input name="itemName" type="text"   id="itemName" value="${ item.itemName }" >  
22 22.     <input name="btnModify"  type="button" id="btnModify" value=“修改" onclick="modifyItem()">  
23 23.</form>  
24 24.註意:   
25 25.1.提交時,設置form的action和methods屬性,然後利用form.submit()函數提交。
複製代碼

菜鳥小結:

       1.對form中的組件驗證時,前兩個使用的是name屬性,包括form自身的。

       2.如果提交表單時沒有反應,同時確定提交表單部分代碼沒有問題,請查看提交表單前面的js代碼,有時前面js的錯誤會引發莫名其妙的問題。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 之前兩篇文章簡析.NET Core 以及與 .NET Framework的關係和.NET Core的構成體系從總體上介紹.NET Core,接下來計劃用一個系列對ASP.NET Core的運行原理進行剖析 ...
  • 在C#編程中,我們經常需要處理這些情況。 1. 某種條件為真時,程式這樣處理;當某種條件為假時,程式那樣處理。 2. 當某種條件為真時,程式一直這樣處理; 這裡的條件,在C#中就是邏輯運算。接下來我就和大家聊聊C#中關於邏輯運算的一些基本概念。 比較運算符 比較運算符,顧名思議就是用來作比較,比較運 ...
  • 如何運用 Form 表單認證 ASP.NET 的安全認證,共有“Windows”“Form”“Passport”“None”四種驗證模式。“Windows”與“None”沒有起到保護的作用,不推薦使用;“Passport”我又沒用過,唉……所以我只好講講“Form”認證了。我打算分三部分: 第一部分 ...
  • // 舉個例子:一個網站有用戶系統、商家系統、網站後臺3個系統 //可以分3個userType, user ,shop , system //網站後臺一般都有角色,如admin,employee //那麼網站的角色就有 user,shop,admin,employee,但是admin和employe ...
  • 這幾天在看Java的一些東西,除了覺的Java和.NET的相似度實在太高之外,就是Java太原始,急需被拯救。之後又回到.NET的思維來,想著怎麼在框架里實現讀寫分離控制請求切換。之前幾個月一直都有在思考,想及對框架現有的代碼改動可能較大,所以遲遲沒怎麼下手。最近終於在廁所蹲下的一瞬間,靈光一閃,感... ...
  • 我的個人博客站在使用百度富文本編輯器UEditor修改文章時,遇到了一些問題,(不知是bug,還是我沒有配置好)。但總算找到瞭解決方法,在此記錄下來。 小站首頁文章列表顯示為(顯示去除HTML標簽後的前600個字元): 具體在 www.zynblog.com 遇到的問題: 正常來講,進入文章修改頁, ...
  • 在這一個練習中,我們要使用帶返回值的方法。如果一個方法帶返回值,那麼它的形式是這樣的。 定義一個帶返回值的C#方法 static 返回類型 方法名字 (參數類型 參數1的名字,參數類型 參數2的名字) { 你的代碼 return 返回值 } static: 先不用管是什麼意思。在沒有講它的含義之前, ...
  • 最近寫了一個SOA服務,開始覺得別人拿到我的服務地址,然後直接添加引用就可以使用了,結果"大牛"告知不行。 讓我寫一個SOAP調用服務的樣例,我有點愣了,因為沒做過這方面的,於是搞到了一個Demo,然後學習了下。 學習如下: 在.Net中有一個對象:WebRequest它可以在後臺直接請求服務的方法 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...