HTML 中的 input 標簽詳解

HTML 中的 input 標簽詳解

一、基礎概念

1. 定義與作用

HTML 中的 <input> 標簽是表單元素的核心組件,用于創建各種用戶輸入字段。作為一個空標簽(沒有閉合標簽),它通過 type 屬性來決定呈現何種輸入控件,是實現用戶與網頁交互的基礎元素。

2. 基本語法
<input type="text" name="username" value="默認值">
  • type:指定輸入類型,如 textpasswordradio 等。
  • name:表單提交時的鍵名,用于服務器端接收數據。
  • value:輸入的值,不同類型有不同表現。

二、常見 input 類型

1. 文本輸入(text)

最基本的輸入類型,用于單行文本輸入。

<input type="text" name="username" placeholder="請輸入用戶名">
  • placeholder:提供提示文本,輸入內容時自動消失。
2. 密碼輸入(password)

輸入內容會被掩碼(通常用圓點)隱藏。

<input type="password" name="password" placeholder="請輸入密碼">
3. 單選按鈕(radio)

用于從多個選項中選擇一個。

<input type="radio" name="gender" value="male" checked><input type="radio" name="gender" value="female">
  • 同一組單選按鈕需使用相同的 name 屬性。
  • checked 屬性設置默認選中項。
4. 復選框(checkbox)

用于多選場景。

<input type="checkbox" name="hobby" value="reading" checked> 閱讀
<input type="checkbox" name="hobby" value="swimming"> 游泳
  • checked 屬性設置默認選中項。
5. 文件上傳(file)

允許用戶上傳文件。

<input type="file" name="avatar" accept="image/*">
  • accept:限制上傳文件類型,如 image/* 表示所有圖片格式。
6. 提交按鈕(submit)

用于提交表單數據到服務器。

<input type="submit" value="提交">
7. 重置按鈕(reset)

用于重置表單所有輸入項為初始值。

<input type="reset" value="重置">
8. 隱藏字段(hidden)

用于存儲不顯示給用戶但隨表單提交的數據。

<input type="hidden" name="userId" value="123">

三、HTML5 新增 input 類型

1. 電子郵件(email)

專門用于輸入電子郵件地址,支持瀏覽器內置驗證。

<input type="email" name="email" placeholder="your@email.com">
2. 網址(url)

用于輸入 URL,自動驗證格式。

<input type="url" name="website" placeholder="https://example.com">
3. 數字(number)

只能輸入數字,支持 minmaxstep 屬性。

<input type="number" name="age" min="1" max="100" step="1">
4. 范圍選擇(range)

通過滑塊選擇值,需指定 minmaxstep

<input type="range" name="volume" min="0" max="100" step="5" value="50">
5. 日期與時間
  • date:選擇日期(年-月-日)
  • time:選擇時間(時:分:秒)
  • datetime-local:選擇日期和時間
<input type="date" name="birthdate">
<input type="time" name="appointment">
<input type="datetime-local" name="meeting">
6. 搜索框(search)

外觀與文本框相似,但在某些瀏覽器中會有特殊處理(如清除按鈕)。

<input type="search" name="query" placeholder="搜索...">
7. 電話號碼(tel)

用于輸入電話號碼,但不強制驗證格式(因全球格式差異大)。

<input type="tel" name="phone" placeholder="請輸入電話號碼">

四、重要屬性詳解

1. 表單相關屬性
  • name:表單提交時的鍵名。
  • value:輸入的值,對提交起作用。
  • disabled:禁用輸入框,值不會被提交。
  • readonly:只讀模式,值會被提交但不可編輯。
2. 驗證屬性
  • required:必填項,提交前必須填寫。
  • minlengthmaxlength:限制文本長度。
  • minmax:限制數字或日期范圍。
  • pattern:使用正則表達式驗證輸入格式。
<input type="text" name="zipcode" pattern="[0-9]{6}" placeholder="郵政編碼">
3. 輔助屬性
  • placeholder:提示文本。
  • autofocus:頁面加載時自動聚焦。
  • autocomplete:啟用或禁用自動完成功能(onoff)。
  • spellcheck:啟用或禁用拼寫檢查(truefalse)。

五、事件處理

<input> 標簽支持多種事件,可通過 JavaScript 監聽并響應。

1. 常見事件
  • onchange:值改變且失去焦點時觸發。
  • oninput:值改變時實時觸發。
  • onfocus:獲得焦點時觸發。
  • onblur:失去焦點時觸發。
2. 示例代碼
<input type="text" id="username" oninput="validate(this)">
<script>function validate(input) {if (input.value.length < 3) {input.style.borderColor = 'red';} else {input.style.borderColor = 'green';}}
</script>

六、樣式與美化

雖然 <input> 的外觀受瀏覽器默認樣式影響,但可通過 CSS 進行定制。

1. 基本樣式修改
input[type="text"] {width: 100%;padding: 10px;border: 1px solid #ccc;border-radius: 4px;box-sizing: border-box;
}
2. 自定義單選按鈕和復選框

通過隱藏原生控件,使用 CSS 創建自定義樣式。

<style>.custom-checkbox input {display: none;}.custom-checkbox span {display: inline-block;width: 20px;height: 20px;border: 1px solid #ccc;border-radius: 3px;}.custom-checkbox input:checked + span {background-color: #2196F3;}
</style>
<div class="custom-checkbox"><input type="checkbox" id="customCheck"><span></span><label for="customCheck">自定義復選框</label>
</div>

七、與 JavaScript 的交互

通過 JavaScript 可動態操作 <input> 元素。

1. 獲取和設置值
const input = document.getElementById('username');
// 獲取值
const value = input.value;
// 設置值
input.value = '新值';
2. 動態禁用/啟用
input.disabled = true; // 禁用
input.disabled = false; // 啟用
3. 表單驗證
function validateForm() {const email = document.getElementById('email');if (!email.checkValidity()) {alert('請輸入有效的電子郵件地址');return false;}return true;
}

八、無障礙性考慮

為提高可訪問性,應注意以下幾點:

1. 使用 label 標簽
<label for="username">用戶名:</label>
<input type="text" id="username" name="username">
2. 添加 ARIA 屬性
<input type="text" id="search" aria-label="搜索產品">
3. 提供錯誤提示
<input type="email" id="email" aria-describedby="emailError">
<span id="emailError" class="error" aria-live="polite"></span>

九、實際應用場景

1. 用戶注冊表單

包含文本、密碼、單選、復選框等多種輸入類型。

2. 搜索功能

使用 search 類型或普通文本框。

3. 數據篩選

結合 rangenumber 實現數值范圍篩選。

4. 文件上傳

圖片、文檔等資源上傳功能。

十、兼容性與注意事項

  1. 新的 input 類型在舊瀏覽器(如 IE)中可能降級為文本框。
  2. 不同瀏覽器對樣式和驗證的實現可能略有差異。
  3. 使用自定義樣式時需注意保持交互體驗一致。

通過合理使用 <input> 標簽及其屬性,可以創建出功能豐富、用戶友好的表單界面,滿足各種 Web 應用的需求。

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

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

相關文章

基于Piecewise Jerk Speed Optimizer的速度規劃算法(附ROS C++/Python仿真)

目錄 1 時空解耦運動規劃2 PJSO速度規劃原理2.1 優化變量2.2 代價函數2.3 約束條件2.4 二次規劃形式 3 算法仿真3.1 ROS C仿真3.2 Python仿真 1 時空解耦運動規劃 在自主移動系統的運動規劃體系中&#xff0c;時空解耦的遞進式架構因其高效性與工程可實現性被廣泛采用。這一架…

2025云上人工智能安全發展研究

隨著人工智能&#xff08;AI&#xff09;技術與云計算的深度融合&#xff0c;云上AI應用場景不斷擴展&#xff0c;但安全挑戰也日益復雜。結合2025年的技術演進與行業實踐&#xff0c;云上AI安全發展呈現以下關鍵趨勢與應對策略&#xff1a; 一、云上AI安全的主要挑戰 數據泄露…

MCU裸機程序如何移植到RTOS?

目錄 1、裸機編程 2、實時操作系統 3、移植裸機程序到RTOS的步驟 步驟1&#xff1a;分析裸機代碼 步驟2&#xff1a;選擇并設置RTOS環境 步驟3&#xff1a;設計任務架構 步驟4&#xff1a;實現任務間通信 步驟5&#xff1a;處理硬件交互 步驟6&#xff1a;測試和調試 …

LangPDF: Empowering Your PDFs with Intelligent Language Processing

LangPDF: Empowering Your PDFs with Intelligent Language Processing Unlock Global Communication: AI-Powered PDF Translation and Beyond In an interconnected world, seamless multilingual document management is not just an advantage—it’s a necessity. LangP…

什么是dom?作用是什么

DOM 的定義 DOM&#xff08;Document Object Model&#xff0c;文檔對象模型&#xff09;是 HTML 和 XML 文檔的編程接口。它將文檔解析為一個由節點和對象組成的樹狀結構&#xff0c;允許開發者通過編程方式動態訪問和操作文檔的內容、結構和樣式。 DOM 的作用 DOM 的主要作…

當AI自我糾錯:一個簡單的“Wait“提示如何讓模型思考更深、推理更強

原論文&#xff1a;s1: Simple test-time scaling 作者&#xff1a;Niklas Muennighoff, Zitong Yang, Weijia Shi等&#xff08;斯坦福大學、華盛頓大學、Allen AI研究所、Contextual AI&#xff09; 論文鏈接&#xff1a;arXiv:2501.19393 代碼倉庫&#xff1a;GitHub - simp…

MYSQL之基本查詢(CURD)

表的增刪改查 表的增加 語法: INSERT [INTO] table_name [(column [, column] ...)] VALUES (value_list) [, (value_list)] ... value_list: value, [, value] ...全列插入和指定列插入 //創建一張學生表 CREATE TABLE students (id INT UNSIGNED PRIMARY KEY AUTO_INCREM…

STM32簡易計算機設計

運用 A0上拉按鈕和 A1 A2下拉按鈕設計按鍵功能 加上獨特的算法檢測設計&#xff0c;先計算&#xff08;&#xff09;內在計算乘除在計算加減的值在計算乘除優先級最后計算加減優先級 #include "stm32f10x.h" #include <stdio.h> #include <stdlib.h>…

sparkSQL讀入csv文件寫入mysql

思路 示例 &#xff08;年齡>18改成>20) mysql的字符集問題 把user改成person “讓字符集認識中文”

計算機視覺與深度學習 | Python 實現SO-CNN-BiLSTM多輸入單輸出回歸預測(完整源碼和源碼詳解)

SO-CNN-BiLSTM **一、代碼實現****1. 環境準備****2. 數據生成(示例數據)****3. 數據預處理****4. 模型構建****5. 模型訓練****6. 預測與評估****二、代碼詳解****1. 數據生成****2. 數據預處理****3. 模型架構****4. 訓練配置****5. 結果可視化****三、關鍵參數說明****四、…

Windows軟件插件-音視頻捕獲

下載本插件 音視頻捕獲就是獲取電腦外接的話筒&#xff0c;攝像頭&#xff0c;或線路輸入的音頻和視頻。 本插件捕獲電腦外接的音頻和視頻。最多可以同時獲取4個視頻源和4個音頻源。插件可以在win32和MFC程序中使用。 使用方法 首先&#xff0c;加載本“捕獲”DLL&#xff0c…

ios打包ipa獲取證書和打包創建經驗分享

在云打包或本地打包ios應用&#xff0c;打包成ipa格式的app文件的過程中&#xff0c;私鑰證書和profile文件是必須的。 其實打包的過程并不難&#xff0c;因為像hbuilderx這些打包工具&#xff0c;只要你輸入的是正確的證書&#xff0c;打包就肯定會成功。因此&#xff0c;證書…

CycleISP: Real Image Restoration via Improved Data Synthesis通過改進數據合成實現真實圖像恢復

摘要 大規模數據集的可用性極大釋放了深度卷積神經網絡(CNN)的潛力。然而,針對單圖像去噪問題,獲取真實數據集成本高昂且流程繁瑣。因此,圖像去噪算法主要基于合成數據開發與評估,這些數據通常通過廣泛假設的加性高斯白噪聲(AWGN)生成。盡管CNN在合成數據集上表現優異…

《Python星球日記》 第70天:Seq2Seq 與Transformer Decoder

名人說:路漫漫其修遠兮,吾將上下而求索。—— 屈原《離騷》 創作者:Code_流蘇(CSDN)(一個喜歡古詩詞和編程的Coder??) 目錄 一、Seq2Seq模型基礎1. 什么是Seq2Seq模型?2. Encoder-Decoder架構詳解1??編碼器(Encoder)2??解碼器(Decoder)3. 傳統Seq2Seq模型的局限性…

Android 性能優化入門(二)—— 內存優化

1、概述 1.1 Java 對象的生命周期 各狀態含義&#xff1a; 創建&#xff1a;分配內存空間并調用構造方法應用&#xff1a;使用中&#xff0c;處于被強引用持有&#xff08;至少一個&#xff09;的狀態不可見&#xff1a;不被強引用持有&#xff0c;應用程序已經不再使用該對象…

GCC 版本與C++ 標準對應關系

GCC 版本 與支持的 C 標準&#xff08;C11、C14、C17、C20、C23&#xff09; 的對應關系 GCC 版本與 C 標準支持對照表 GCC 版本默認 C 標準C11C14C17C20C23GCC 4.8C98? (部分支持)????GCC 4.9C98? (完整支持)????GCC 5.1C98?? (完整支持)???GCC 6.1C14??? …

5、事務和limit補充

一、事務【都是重點】 1、了解 一個事務其實就是一個完整的業務邏輯。 要么同時發生&#xff0c;要么同時結束。 是一個最小的工作單元。 不可再分。 看這個視頻&#xff0c;黑馬的&#xff0c;4分鐘多點就能理解到 可以理解成&#xff1a; 開始事務-----如果中間拋出異常…

一套基于 Bootstrap 和 .NET Blazor 的開源企業級組件庫

前言 今天大姚給大家分享一套基于 Bootstrap 和 .NET Blazor 的開源企業級組件庫&#xff1a;Bootstrap Blazor。 項目介紹 BootstrapBlazor 是一套基于 Bootstrap 和 Blazor 的開源&#xff08;Apache License&#xff09;、企業級組件庫&#xff0c;無縫整合了 Bootstrap …

mac-M系列芯片安裝軟件報錯:***已損壞,無法打開。推出磁盤問題

因為你安裝的軟件在Intel 或arm芯片的mac上沒有簽名導致。 首先打開任何來源操作 在系統設置中配置&#xff0c;如下圖&#xff1a; 2. 然后打開終端&#xff0c;輸入&#xff1a; sudo spctl --master-disable然后輸入電腦鎖屏密碼 打開了任何來源&#xff0c;還遇到已損壞…

RK3568-鴻蒙5.1與原生固件-扇區對比分析

編譯生成的固件目錄地址 ../openharmony/out/rk3568/packages/phone/images鴻蒙OS RK3568固件分析 通過查看提供的信息&#xff0c;分析RK3568開發板固件的各個組件及其用途&#xff1a; 主要固件組件 根據終端輸出的文件列表&#xff0c;RK3568固件包含以下關鍵組件&#x…