首頁 >web前端 >css教學 >建立一個登入表單網站

建立一個登入表單網站

WBOY
WBOY原創
2024-09-03 14:08:02707瀏覽

Build a Login Form Website

介紹

開發者們大家好!我很高興分享我的最新項目:登入表單。該專案非常適合希望建立一個乾淨且功能齊全的登入介面的人,使用者可以使用該介面來驗證自己的身份。這是使用 HTML、CSS 和 JavaScript 增強前端開發技能的好方法,同時創建專業的使用者驗證體驗。

項目概況

登入表單是一個網路應用程序,旨在為用戶提供安全且用戶友好的方式登入網站。它採用現代且響應式的設計,允許使用者輸入憑證並存取網站的受保護區域。此專案示範如何建立功能齊全且美觀的登入表單。

特徵

  • 響應式佈局:登入表單適應不同的螢幕尺寸,在桌面和行動裝置上提供最佳的檢視體驗。
  • 互動式元素:包含表單驗證和錯誤訊息等功能,以引導使用者完成登入程序。
  • 簡潔的設計:以視覺上有吸引力且易於使用的格式呈現登入欄位。

使用的技術

  • HTML:提供登入表單的結構。
  • CSS:設定表單樣式以建立現代且響應式的設計。
  • JavaScript:管理互動元素,包括表單驗證和錯誤處理。

專案結構

以下是項目結構的概述:

Login-Form/
├── index.html
├── style.css
└── script.js
  • index.html:包含登入表單的 HTML 結構。
  • style.css:包含 CSS 樣式以創造引人入勝且響應式的設計。
  • script.js:管理表單的互動元素,例如驗證。

安裝

要開始該項目,請按照以下步驟操作:

  1. 複製儲存庫

    git clone https://github.com/abhishekgurjar-in/Login-Form.git
    
  2. 開啟專案目錄:

    cd Login-Form
    
  3. 運行項目:

    • 在網頁瀏覽器中開啟index.html檔案以查看登入表單。

用法

  1. 在網頁瀏覽器中開啟表單
  2. 在輸入欄位中輸入您的憑證
  3. 提交表單來測試驗證和錯誤處理。
  4. 查看錯誤訊息如果輸入欄位未正確填入。

程式碼說明

超文本標記語言

index.html 檔案定義了登入表單的結構,包括使用者名稱和密碼的輸入欄位以及提交按鈕。這是一個片段:

8b05045a5be5764f313ed5b9168a17e6
49099650ebdc5f3125501fa170048923
  93f0f5c25f18dab9d176bd4f6de5d30e
    7c8d9f814bcad6a1d7abe4eda5f773e5
    acd8feeb3a0ea7477b979779de32785a
    26faf3d1af674280d03ba217d87e9421
    af75c476cdb7e6c074ca6da9b40841de
    90392ec4442ad9ff612213ec639da4832cacc6d41bbb37262a98f745aa00fbf0
    b2386ffb911b14667cb8f0f91ea547a7Login Form6e916e0f7d1e588d4f442bf645aedb2f
  9c3bca370b5104690d9ef395f2c5f8d1
  6c04bd5ca3fcae76e30b72ad730ca86d
    4883ec0eb33c31828b7c767c806e14c7
      aceaa8cc7465de093c281ce67939f861
        e372ff8e7ef0a158f0cfb75b8f3c7ce1
        4a249f0d628e2318394fd9b75b4636b1Login Form473f0a7621bec819994bb5020d29372a
      16b28748ea4df4d9c2150843fecfba68
      bcd0e077a4e74a5cf996a27d3f409594
        91a06508ad7699447d37a226f0569c02Register Now0f6dfd1e3624ce5465eb402e300e01ae
        ff9c23ada1bcecdd1a0fb5d5a0f18437
          b9600acbcae46ed1cdd8825e541c0b79
            057cfe8a71fabb55b80b425c9d1a53e5Email8c1ecd4bb896b2264e0711597d40766c
            366f91de1890a91bd4c61d6337cee49d
          16b28748ea4df4d9c2150843fecfba68
          b9600acbcae46ed1cdd8825e541c0b79
            209d759cd66b58fc7c45834f2e99c573Password8c1ecd4bb896b2264e0711597d40766c
            985c764dbaf67f3082c332a7f19903c1
          16b28748ea4df4d9c2150843fecfba68
          dc6dce4a544fdca2df29d5ac0ea9906b
            0346fba700925f13d59069990bdd94c2Register65281c5ac262bf6d81768915a4a77ac0
          16b28748ea4df4d9c2150843fecfba68
        f5a47148e367a6035fd7a2faa965022e
      16b28748ea4df4d9c2150843fecfba68
    16b28748ea4df4d9c2150843fecfba68

    5eaa4ceadfbb9d829f6aaf137beff062
      684271ed9684bde649abda8831d4d355Password must contain the following:39528cedfa926ea0c01e69ef5b2ea9b0
      d3def2ef45fb5468d11098b963064271A a4b561c25d9afb9ac8dc4d70affff419lowercase0d36329ec37a2cc24d42c7229b69747a letter94b3e26ee717c64999d7867364b1b4a3
      19ac74fb1ae957e0ce100244ae583241A a4b561c25d9afb9ac8dc4d70affff419capital (uppercase)0d36329ec37a2cc24d42c7229b69747a letter94b3e26ee717c64999d7867364b1b4a3
      ad11d40df8382c4ac6e31ff9d372ad80A a4b561c25d9afb9ac8dc4d70affff419number0d36329ec37a2cc24d42c7229b69747a94b3e26ee717c64999d7867364b1b4a3
      5f61ea5388eebd151226ff32d1adfbeeMinimum a4b561c25d9afb9ac8dc4d70affff4198 characters0d36329ec37a2cc24d42c7229b69747a94b3e26ee717c64999d7867364b1b4a3
    16b28748ea4df4d9c2150843fecfba68

    ffd6ba4147bda351239915f463e46e38
      e388a4556c0f65e1904146cc1a846beeMade with ❤️ by Abhishek Gurjar94b3e26ee717c64999d7867364b1b4a3
    16b28748ea4df4d9c2150843fecfba68
  36cc49f0c466276486e50c850b7e4956
73a6ac4ed44ffec12cee46588e518a5e

CSS

style.css 檔案設定登入表單的樣式,確保其具有視覺吸引力和回應能力。以下是一些關鍵樣式:

@import url("https://fonts.googleapis.com/css?family=Poppins:400,500,600,700,800,900");

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: 0;
  font-family: "Poppins", sans-serif;
  background: #102770;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.container {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  text-align: center;
  margin-top: 8px;
  margin-bottom: 15px;
}

#LoginForm img {
  width: 100px;
  height: 100px;
}

#LoginForm h1 {
  padding-bottom: 40px;
  color: white;
}

.form_area {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 100%;
  max-width: 360px;
  border-radius: 25px;
  background-color: #ecf0f1;
  border: 10px solid rgba(0, 0, 0, 0.05);
}

.title {
  font-weight: 900;
  font-size: 1.5em;
  margin-top: 20px;
}

.sub_title {
  font-weight: 600;
  margin: 5px 0;
}

.form_group {
  display: flex;
  flex-direction: column;
  margin: 20px;
  align-items: baseline;
}

.form_style {
  outline: none;
  width: 250px;
  font-size: 15px;
  border-radius: 4px;
  padding: 12px;
  border: none;
}

.form_style:focus {
  border: 1px solid #8e8e8e;
}

.btn {
  background-color: #000000;
  color: white;
  margin: 20px 0;
  padding: 15px;
  width: 270px;
  font-size: 15px;
  border-radius: 10px;
  font-weight: bold;
  cursor: pointer;
  border: none;
  transition: all 0.2s ease;
}

.btn:hover {
  background-color: rgb(41, 40, 40);
}

#message {
  display: none;
  text-align: center;
  color: #ffffff;
}

#message p {
  padding: 10px 35px;
  font-size: 18px;
}

.valid {
  color: green;
}

.valid:before {
  content: "✔";
  margin-right: 10px;
}

.invalid {
  color: red;
}

.invalid:before {
  content: "✖";
  margin-right: 10px;
}

.footer {
  color: white;
  margin: 20px;
  text-align: center;
}

JavaScript

script.js 檔案包含表單驗證的功能。這是一個簡單的示範片段:

let passInput = document.getElementById("password");
let letter = document.getElementById("letter");
let capital = document.getElementById("capital");
let number = document.getElementById("number");
let length = document.getElementById("length");

passInput.onfocus = function() {
  document.getElementById("message").style.display = "block";
};

passInput.onblur = function() {
  document.getElementById("message").style.display = "none";
};

passInput.onkeyup = function() {
  let lowerCaseLetters = /[a-z]/g;
  if (passInput.value.match(lowerCaseLetters)) {
    letter.classList.remove("invalid");
    letter.classList.add("valid");
  } else {
    letter.classList.remove("valid");
    letter.classList.add("invalid");
  }

  let upperCaseLetters = /[A-Z]/g;
  if (passInput.value.match(upperCaseLetters)) {
    capital.classList.remove("invalid");
    capital.classList.add("valid");
  } else {
    capital.classList.remove("valid");
    capital.classList.add("invalid");
  }

  let numbers = /[0-9]/g;
  if (passInput.value.match(numbers)) {
    number.classList.remove("invalid");
    number.classList.add("valid");
  } else {
    number.classList.remove("valid");
    number.classList.add("invalid");
  }

  if (passInput.value.length >= 8) {
    length.classList.remove("invalid");
    length.classList.add("valid");
  } else {
    length.classList.remove("valid");
    length.classList.add("invalid");
  }
};

現場演示

您可以在此處查看登入表單項目的現場示範。

結論

建立登入表單對於建立功能齊全且使用者友好的身份驗證介面來說是一次很棒的體驗。該專案強調了表單驗證和簡潔設計在現代 Web 開發中的重要性。透過應用 HTML、CSS 和 JavaScript,我們開發了一個登入表單,作為使用者驗證的關鍵元件。我希望這個專案能夠激勵您建立自己的登入或身份驗證表單。快樂編碼!

製作人員

這個專案是我在 Web 開發方面持續學習之旅的一部分。

作者

  • 阿布舍克·古賈爾
    • GitHub 簡介

以上是建立一個登入表單網站的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn