>웹 프론트엔드 >CSS 튜토리얼 >로그인 양식 웹사이트 구축

로그인 양식 웹사이트 구축

WBOY
WBOY원래의
2024-09-03 14:08:02703검색

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. 입력 필드가 올바르게 채워지지 않은 경우 오류 메시지를 확인하세요.

코드 설명

HTML

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;
}

자바스크립트

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");
  }
};

라이브 데모

여기에서 로그인 양식 프로젝트의 라이브 데모를 확인할 수 있습니다.

결론

로그인 양식을 구축하는 것은 기능적이고 사용자 친화적인 인증 인터페이스를 만드는 데 있어서 좋은 경험이었습니다. 이 프로젝트는 현대 웹 개발에서 양식 유효성 검사와 깔끔한 디자인의 중요성을 강조합니다. HTML, CSS, JavaScript를 적용하여 사용자 인증의 중요한 구성 요소인 로그인 양식을 개발했습니다. 이 프로젝트가 여러분이 자신만의 로그인 또는 인증 양식을 만드는 데 영감을 주기를 바랍니다. 즐거운 코딩하세요!

크레딧

이 프로젝트는 웹 개발에 대한 지속적인 학습 여정의 일환으로 개발되었습니다.

작가

  • 아비셰크 구자르
    • GitHub 프로필

위 내용은 로그인 양식 웹사이트 구축의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.