JavaScript:表單及正則表達式驗證

今天我要介紹的是在JavaScript中關于表單驗證內容的知識點介紹:

關于表單驗證,我接下來則直接將內容以及效果顯示出來并作注解,這樣可以清晰看見這個表達驗證的妙用:

<form id="ff" action="https://www.baidu.com"><h1>用戶登錄</h1>賬號:<input type="text" id="zh" /> <span></span> <br />密碼:<input type="password" id="mm" /><span></span> <br /><Button>登錄</Button></form>

效果:

? ? ? ?注:可以看到這是一個非常經典的登錄界面的制作,下面我會逐一介紹他們內部的方法使用以及代碼顯示的效果;

onclick: 點擊事件? ?//ondblclick: 雙擊事件?// onsubmit: 表單提交事件?// onblur: 失去焦點事件?// onfocus: 獲取焦點事件。

注: 這是事件點擊使用的方法代碼;

表單提交的代碼演示:

document.getElementById('ff(自定義)').onsubmit = function() {console.log('觸發了onsubmit');// 獲取表單中的賬號和密碼let zh = document.getElementById("zh").value;let mm = document.getElementById("mm").value;// 判斷賬號及密碼是否為空if (zh.length == 0 || mm.length == 0) {alert('請輸入正確的賬號或密碼')// 自定義彈出框document.querySelector('.mask').style.display = "block";return false;}// 以下結果為true 表允許表單提//交到指定頁面,反之則不能,且只能實現所輸入的結果return true;}

?注{? return false? }為阻止表單提交,但如果整體代碼無錯,{?return true?}則通過,提交表單。

效果:

?

賬號和密碼獲取/失去焦點演示:

         // 賬號獲取焦點事件document.getElementById('zh').onfocus = function() {// let = zh = this.value;this.nextElementSibling.innerHTML = "";}// 賬號失去焦點事件document.getElementById('zh').onblur = function() {let = zh = this.value;let f = zh.length == 0;console.log(zh);this.nextElementSibling.innerHTML = f ? "×" : "√";// this.nextElementSibling.style.display=f?"block":"none";}// 密碼獲取焦點事件document.getElementById('mm').onfocus = function() {// let = zh = this.value;this.nextElementSibling.innerHTML = "";}// 密碼失去焦點事件document.getElementById('mm').onblur = function() {let = zh = this.value;let f = zh.length == 0;console.log(zh);this.nextElementSibling.innerHTML = f ? "×" : "√";// this.nextElementSibling.style.display=f?"block":"none";}

?注:注意看賬號和密碼的代碼格式內容,兩者設置的自定義不同,并非全部都是一樣

效果:

?密碼:

?注:當內容存在焦點時則有判斷,有內容則成立,無內容則錯誤,不成立,無法進行表單提交

?正則表達式:

<!-- 正則表達式是用于對數據格式進行判斷 -->
?? ??? ?<!-- 定義正則表達式: var rex = /^\d$\(\d表0-0的數字) -->
?? ??? ?
?? ??? ?<!-- 1.內容(以\開頭) -->
?? ??? ?<!-- \d:表0-9的數字 -->
?? ??? ?<!-- \w:表0-9a-zA-Z_ -->? ? ? (非:不是,表示否定之意,這里注意
?? ??? ?<!-- \D:表非0-9的數字 -->
?? ??? ?<!-- \W:表非0-9a-zA-Z -->
?? ??? ?<!-- .表任意一個單個字符 -->
?? ??? ?
?? ??? ?<!-- 2.字符出現速度 -->
?? ??? ?<!-- ?表0 or 一次 -->
?? ??? ?<!-- +表一次或者多次 -->
?? ??? ?<!-- *表0此或多次 -->
?? ??? ?<!-- \d{5}表五個數字 -->
?? ??? ?<!-- \d{5,10}表至低五個,至高十個 -->

?例:

// 例一:var rex = /^[A-Z]{1}\w{5,11}$/console.log(rex.test('Zking1234'));

效果:

?注:開頭小寫不成立,不滿足;

例:

// // QQ號案例1184995259@qq.comvar rex1 = /^\d{5,12}@qq.com$/console.log(rex.test('1136889226@qq.com'));

注:后面的??@qq.com? 為固定值

以正則表達式為方法的登錄界面:

注:(效果與表單驗證同理,但是在其基礎上用正則表達式的方式進行使用。)

<form id="ff" action=""><h1>用戶登錄</h1>賬號:<input type="text" id ="zh" /> <span></span> <br />密碼:<input type="text" id="mm" /><span></span> <br /><Button>登錄</Button></form><input type="text" id ="mm1"  /><span></span>document.getElementById("ff").onsubmit=function(){// 定義賬號的驗證規則var rex1 = /^[a-z]{5,10}$/// 定義密碼 var rex2 = /^[a-z0-9A-Z.]{5,10}$/var username = rex1.test(zh.value);console.log(usernam);if(username){zh.nextElementSibling.style="color:blue";zh.nextElementSibling.innerHTML="對";}else{zh.nextElementSibling.style="color:green";zh.nextElementSibling.innerHTML="錯";}var password = rex2.test(mm.value);console.log(password);if(password){mm.nextElementSibling.style="color:blue";mm.nextElementSibling.innerHTML="對";}else{mm.nextElementSibling.style="color:green";mm.nextElementSibling.innerHTML="錯";}return username&&password;}

注:關鍵點:return username&&password;??

效果:

?注:未輸入內容時的效果;

注:輸入內容與為輸入內容時的對照。

密碼安全級別強度驗證:

document.getElementById('mm1').onkeyup=function(){let c = 0;var rex1 = /^.*\d.*$/;  //包含數字var rex2 = /^.*[a-z].*$/; //包含字母var rex3 = /^.*[A-Z].*$/; //包含大寫字母var rex4 = /^.*[@.].*$/; //包含特殊符號let m = this.value;if(rex1.test(m)){c++;}if(rex2.test(m)){c++;}if(rex3.test(m)){c++;}if(rex4.test(m)){c++;}let arr=['弱','中等','強','超強']if(m.length==0){this.nextElementSibling.innerHTML="";}else{this.nextElementSibling.innerHTML=arr[c-1];}}

效果:

釋義

let arr=['弱','中等','強','超強']if(m.length==0){this.nextElementSibling.innerHTML="";}else{this.nextElementSibling.innerHTML=arr[c-1];   《==}

注:c-1 由強至弱反向,由弱至強正向,

總結:希望本篇有關于JavaScript表單驗證和正則表達式的知識點內容能對你帶來一定的幫助,同時非常感謝各位大佬們的點贊與支持,咱們下一篇不見不散。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/77006.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/77006.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/77006.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

天元證券|調倉曝光!首批科技基金一季報出爐

4月15日&#xff0c;中歐基金、永贏基金、長城基金等公募基金公司旗下部分權益類基金產品一季報出爐。 券商中國記者梳理發現&#xff0c;永贏信息產業智選混合主要聚焦信息技術領域布局&#xff0c;前十大重倉股中9只股票屬于信息技術行業&#xff0c;合計占基金資產凈值比例達…

SpringAI版本更新:向量數據庫不可用的解決方案!

Spring AI 前兩天&#xff08;4.10 日&#xff09;更新了 1.0.0-M7 版本后&#xff0c;原來的 SimpleVectorStore 內存級別的向量數據庫就不能用了&#xff0c;Spring AI 將其全部源碼刪除了。 此時我們就需要一種成本更低的解決方案來解決這個問題&#xff0c;如何解決呢&…

Sklearn入門之datasets的基本用法

、 Sklearn全稱:Scipy-toolkit Learn是 一個基于scipy實現的的開源機器學習庫。它提供了大量的算法和工具&#xff0c;用于數據挖掘和數據分析&#xff0c;包括分類、回歸、聚類等多種任務。本文我將帶你了解并入門Sklearn下的datasets在機器學習中的基本用法。 獲取方式 pi…

優化 Dockerfile 性能之實踐(Practice of Optimizing Dockerfile Performance)

優化 Dockerfile 性能之實踐 構建 Docker 鏡像時&#xff0c;Dockerfile 的性能會顯著影響構建過程的效率。經過優化的 Dockerfile 可以縮短構建時間、最小化鏡像大小并提高整體容器性能。在本文中&#xff0c;我們將探討優化 Dockerfile 性能的最佳實踐。 盡量減少層數 影響…

出現 ERR_CERT_COMMON_NAME_INVALID | 301 302 重定向的解決方法

目錄 前言1. 問題所示2. 原理分析3. 解決方法前言 ?? 找工作,來萬碼優才:?? #小程序://萬碼優才/r6rqmzDaXpYkJZF 爬蟲神器,無代碼爬取,就來:bright.cn 1. 問題所示 執行代碼時,出現如下提示: GET https://xxxx/admin-api/system

C語言 —— 指尖躍遷 刻印永恒 - 文件操作

目錄 1. 什么是文件 1.1 程序文件 1.2 數據文件 1.3 文件名 2. 二進制文件和文本文件 3. 文件的打開與關閉 3.1 流和標準流 3.2 文件指針 3.3 文件的打開與關閉 fopen fclose 4. 文件的順序讀寫 4.1 fgetc和fputc fgetc fputc 4.2 fgets和fputs fgets fputs…

用css給div列表加個序號

用 CSS 的 counter 相關屬性來為列表添加序號。以下是具體的代碼&#xff0c;我將以 HTML 文件的形式提供&#xff0c;并且會運行展示效果&#xff1a; .as-div {// counter-reset: my-counter; /* 計數器名稱是my-counter */// counter-reset: small-apple; /* 計數器名稱是s…

Rust : 關于*const () 與type erase

*const () 可以替代泛型&#xff0c;更加靈活。 一、 代碼 //use std::mem::transmute; trait Work {fn process(&self); } struct Foo(String);impl Work for Foo {fn process(&self) {println!("process work from Foo : {}", self.0);} } struct Bar(S…

【專題刷題】雙指針(二)

&#x1f4dd;前言說明&#xff1a; 本專欄主要記錄本人的基礎算法學習以及LeetCode刷題記錄&#xff0c;按專題劃分每題主要記錄&#xff1a;&#xff08;1&#xff09;本人解法 本人屎山代碼&#xff1b;&#xff08;2&#xff09;優質解法 優質代碼&#xff1b;&#xff…

吉爾吉斯斯坦工商會代表團赴齊河德瑞新能源汽車考察

德州齊河&#xff0c;2025年4月15日電 時中美貿易突變之際&#xff0c;乘國家一帶一路之風。 展中國新能源之宏圖&#xff0c;塑國貿體系之新方向。 今日上午&#xff0c;吉爾吉斯斯坦共和國工商會代表團一行三人受邀抵達濟南&#xff0c;開啟對德瑞新能源科技有限公司&…

【記錄condapack打包環境到超算上順利運行】

以安裝CLRNet為例子 本地Linux系統上的操作步驟。 由于官方的安裝包的步驟&#xff0c;執行condapack的時候會報錯&#xff0c;所以使用以下步驟進行安裝包。 安裝其他 Python 依賴包 pip install -r requirements.txt? 二、構建并打包項目&#xff08;核心步驟&#xff…

Windows OpenUtau-v0.1.529-開源歌曲合成軟件[提供MIDI編輯、歌詞調整、音色修改 等功能,音樂創作者的必備工具]

Windows OpenUtau 鏈接&#xff1a;https://pan.xunlei.com/s/VONy_Refvo6_813Ig--nu5_rA1?pwdejzc# 引擎&#xff08;Resampler&#xff09;和拼接器&#xff08;Wavtool&#xff09;是UTAU協議中音頻處理的兩大組件。前端編輯器通過調用引擎和拼接器&#xff0c;對音頻進行…

虛擬卡可以解決訂閱 ChatGPT 時無法付款的問題

在全球掀起 AI 熱潮的今天&#xff0c;因為工作的需要有些朋友要用ChatGPT&#xff0c;它也成為了不少人日常學習、工作、創作和編程的得力助手。然而&#xff0c;不少用戶在嘗試訂閱 ChatGPT Plus&#xff08;付費版&#xff09;時&#xff0c;卻遇到了一個令人頭疼的問題——…

設計模式之狀態模式:優雅管理對象行為變化

引言 狀態模式&#xff08;State Pattern&#xff09;是一種行為型設計模式&#xff0c;它允許對象在其內部狀態改變時改變它的行為&#xff0c;使對象看起來似乎修改了它的類。狀態模式將狀態轉移邏輯和狀態相關行為封裝在獨立的狀態類中&#xff0c;完美解決了復雜條件判斷問…

【算法】歸并排序

算法系列七&#xff1a;歸并排序 一、歸并排序的遞歸探尋 1.思路 2.搭建 2.1設計過掉不符情況&#xff08;在最底層時&#xff09; 2.2查驗能實現基礎排序&#xff08;在最底層往上點時&#xff09; 2.3跳轉結果繼續往上回搭 3.實質 4.實現 二、遞歸的調用棧 1.遞歸的…

線束線纜從二維設計到虛擬驗證全流程解決方案

一、傳統設計中的痛點 線纜的開發設計是橫跨多專業多學科的龐大工程&#xff0c;通常會劃分為幾大階段逐次推進&#xff0c;由于每個階段的工作任務不同&#xff0c;所以在不同設計階段使用的工具也完全不同&#xff0c;由此導致整個設計流程中工程師常常要跨平臺協作&#xf…

【智駕中的大模型 -1】自動駕駛場景中的大模型

1. 前言 我們知道&#xff0c;大模型現在很火爆&#xff0c;尤其是 deepseek 風靡全球后&#xff0c;大模型毫無疑問成為為中國新質生產力的代表。百度創始人李彥宏也說&#xff1a;“2025 年可能會成為 AI 智能體爆發的元年”。 隨著科技的飛速發展&#xff0c;大模型的影響…

個人博客系統后端 - 注冊登錄功能實現指南

一、功能概述 個人博客系統的注冊登錄功能包括&#xff1a; 用戶注冊&#xff1a;新用戶可以通過提供用戶名、密碼、郵箱等信息創建賬號用戶登錄&#xff1a;已注冊用戶可以通過用戶名和密碼進行身份驗證&#xff0c;獲取JWT令牌身份驗證&#xff1a;使用JWT令牌訪問需要認證…

投行交易與風控系統的消費側冪等架構設計與實戰

1.背景和痛點 1.1 資金操作敏感性場景 核心需求&#xff1a; 交易唯一性&#xff1a;資金類操作必須保證全局唯一執行計算原子性&#xff1a;風控指標計算需具備事務性特征審計追溯&#xff1a;所有操作需保留完整冪等軌跡 1.2 業務損失統計 二、技術挑戰與架構設計 2.1 分…

odoo-046 視圖顯示的 name 數據庫中存儲的不一樣

文章目錄 一、問題由來二、排查經過1. 問 deepseek2. 驗證3. 新問題 三、 總結四、補充&#xff08;翻譯模型 ir.translation 中 src 和 value 字段詳解&#xff09; 一、問題由來 客戶有多個公司&#xff0c;使用多個數據庫。他們有時需要同步不同數據庫之間的數據的需求。在…