JavaScript | 基礎表單驗證(純Js)

来源:http://www.cnblogs.com/hughdong/archive/2017/07/19/7206744.html
-Advertisement-
Play Games

———————————————————————————————————————————— 基礎表單驗證(純js) - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ...


————————————————————————————————————————————

基礎表單驗證(純js

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

驗證思路

   

  • 監聽每個input控制項的焦點離開(onblue),當焦點離開時調用驗證函數,驗證後修改第三欄文字,顯示符合/不符合併返回true/false

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

實現代碼:

index.html

 1 <!DOCTYPE html>
 2 <html>
 3 
 4 <head>
 5     <title></title>
 6     <link rel="stylesheet" href="css.css">
 7 </head>
 8 
 9 <body>
10     <form id="form" action="" method="post" onsubmit="return vilidate()">
11         <table class="table">
12             <tr>
13                 <td>雇員編號</td>
14                 <td>
15                     <input type="text" id="empnb" name="empnb" onblur="validateEmpnb()">
16                 </td>
17                 <td>
18                     <span id="empnbMsg"></span>
19                 </td>
20             </tr>
21             <tr>
22                 <td>雇員姓名</td>
23                 <td>
24                     <input type="text" id="ename" name="ename" onblur="validateEname()">
25                 </td>
26                 <td>
27                     <span id="enameMsg"></span>
28                 </td>
29             </tr>
30             <tr>
31                 <td>雇員職位</td>
32                 <td>
33                     <input type="text" name="epost" id="epost" onblur="validateEpost()">
34                 </td>
35                 <td>
36                     <span id="epostMsg"></span>
37                 </td>
38             </tr>
39             <tr>
40                 <td>雇員日期</td>
41                 <td>
42                     <input type="text" name="" id="edate" name="edate" onblur="validateEdate()">
43                 </td>
44                 <td>
45                     <span id="edateMsg"></span>
46                 </td>
47             </tr>
48             <tr>
49                 <td>基本工資</td>
50                 <td>
51                     <input type="text" name="esalary" id="esalary" onblur="validateEsalary()">
52                 </td>
53                 <td>
54                     <span id="esalaryMsg"></span>
55                 </td>
56             </tr>
57             <tr>
58                 <td>佣金</td>
59                 <td>
60                     <input type="text" name="ebrok" id="ebrok" onblur="validateEbrok()">
61                 </td>
62                 <td>
63                     <span id="ebrokMsg"></span>
64                 </td>
65             </tr>
66             <tr>
67                 <td colspan="3">
68                     <input type="submit" autofocus="autofocus">
69                     <input type="reset">
70                 </td>
71             </tr>
72         </table>
73     </form>
74 </body>
75 <script type="text/javascript" src="./FormValidation.js"></script>
76 
77 </html>

FormValidation.js

 1 // 日期選擇
 2 function layDate() {
 3 
 4 }
 5 
 6 // 驗證雇員編號,4位純數字編號
 7 function validateEmpnb() {
 8     return validateRegexp("empnb", /^\d{4}$/);
 9 }
10 // 驗證雇員姓名,不為空
11 function validateEname() {
12     return validateNull("ename");
13 }
14 // 驗證雇員職位,不為空
15 function validateEpost() {
16     return validateNull("epost");
17 }
18 // 驗證雇員日期
19 function validateEdate() {
20     return validateRegexp("edate", /^\d{4}-\d{2}-\d{2}$/)
21 }
22 // 驗證基本工資
23 function validateEsalary() {
24     return validateRegexp("esalary", /^\d+(\.\d{1,2})?$/)
25 }
26 // 驗證佣金
27 function validateEbrok() {
28     return validateRegexp("ebrok", /^\d+(\.\d{1,2})?$/)
29 }
30 
31 // 提交時全部重新驗證
32 function validate() {
33     return validateEmpnb() && validateEname() && validateEpost() && validateEdate() && validateEsalary() && validateEbrok();
34 }
35 // 正則表達式驗證
36 function validateRegexp(elemName, regexp) {
37     var elem = document.getElementById(elemName);
38     var msg = document.getElementById(elemName + 'Msg')
39     console.log(regexp);
40     console.log(elem.value);
41     if (regexp.test(elem.value)) {
42         msg.innerHTML = 'ok';
43         msg.style.color = 'green';
44         return true;
45     } else {
46         msg.innerHTML = '您的輸入不符合規則';
47         msg.style.color = 'red';
48         return false;
49     }
50 }
51 // 不為空驗證
52 function validateNull(elemName) {
53     var elem = document.getElementById(elemName);
54     var msg = document.getElementById(elemName + 'Msg');
55     console.log(elem.value);
56     console.log(msg);
57     if (elem.value == '' || elem.value == ' ') {
58         msg.innerHTML = '您的輸入不能為空';
59         msg.style.color = 'red';
60         return false;
61     } else {
62         msg.innerHTML = 'ok';
63         msg.style.color = 'green';
64         return true;
65     }
66 }

css.css

 1 html {
 2     font-size: 14px;
 3 }
 4 
 5 .table {
 6     border: 1px grey solid;
 7 }
 8 
 9 .table tr {
10     height: 2rem;
11 }
12 
13 .table td {
14     width: 15rem;
15 }


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

-Advertisement-
Play Games
更多相關文章
  • Proxy var engineer = { name: 'Joe Sixpack', salary: 50 }; var interceptor = { set: function (receiver, property, value) { console.log(property, 'is ch ...
  • (1)檢查node版本 在安裝vue的環境之前,安裝NodeJS環境是必須的。可以使用node -v指令檢查,需要保證安裝了4.0版本以上的nodeJS環境。 當然,沒有安裝的話,去Node.js的官網下載一下,各種下一步,傻瓜式安裝就好,非常方便。 tips:這裡說一下我自己踩過的一個坑,我最開始 ...
  • 1、下載地址:https://github.com/kartik-v/bootstrap-fileinput/ 打開壓縮包中的example/index.html查看示例。根據示例的代碼選擇需要的控制項代碼使用。 2、需要結合bootstrap使用,即頁面需要引入bootstrap相關js和css文件 ...
  • 代碼下載:https://github.com/lima-helen/vue-click-link 解決辦法有很多,之前也有看到同學用的是跳轉到空白頁,然後再跳路由以達到監控路由的目的; 這裡的解決辦法是: 在bottom.vue中接收並wath 該數值以達到不同數值為不同的狀態 ...
  • for迴圈裡面的break;和continue;語句 break語句 哇,我已經找到我要的答案了,我不需要進行更多的迴圈了! 比如,尋找第一個能被5整除的數: for迴圈中,如果遇見了break語句,這個for迴圈就會立即終止,不在進行其他的迭代了。 for(var i = 1 ; i <= 100 ...
  • 事件的預設傳播機制: 捕獲階段:從外向里依次查找元素 目標階段:從當前事件源本身的操作 冒泡階段:從內到外依次觸發相關的行為(我們最常用的就是冒泡階段) 具體見下圖: ...
  • 1、z-index基礎 z-index含義:指定了元素及其子元素的”z順序“,而”z順序“可以決定元素的覆蓋順序。z-index值越大越在上面。 z-index值:auto(預設值);integer(整數值);inherit(繼承)。 z-index基本特性:①支持負值;②支持CSS3 animat ...
  • 代碼下載地址:https://github.com/lima-helen/vue-cli- Vue-cli和element ui配置網上都有,這裡就不多說了; ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...