> 웹 프론트엔드 > JS 튜토리얼 > 모기지 계산기 웹사이트 구축

모기지 계산기 웹사이트 구축

PHPz
풀어 주다: 2024-08-31 06:35:03
원래의
339명이 탐색했습니다.

Build a Mortgage Calculator Website

소개

안녕하세요, 개발자 여러분! 저의 최신 프로젝트인 모기지 계산기를 공유하게 되어 기쁩니다. 이 프로젝트는 HTML, CSS 및 JavaScript를 사용하여 모기지 지불금을 계산하는 실용적인 대화형 웹 애플리케이션을 구축하려는 사람들에게 이상적입니다. 이는 프런트엔드 개발 기술을 향상시키고 개인 재무 관리에 유용한 도구를 만드는 환상적인 방법입니다.

프로젝트 개요

모기지 계산기는 사용자가 모기지 지불금과 총 상환 금액을 계산하는 데 도움을 주기 위해 설계된 웹 애플리케이션입니다. 깔끔하고 직관적인 인터페이스를 갖춘 이 프로젝트는 실제 시나리오에서 사용할 수 있는 기능적이고 대화형 웹 도구를 만드는 방법을 보여줍니다.

특징

  • 대화형 계산기: 사용자는 모기지 금액, 기간, 이자율을 입력하여 정확한 계산을 얻을 수 있습니다.
  • 상환 옵션: 원리금 상환과 이자만 상환 옵션을 제공합니다.
  • 반응형 디자인: 애플리케이션은 완벽하게 반응하므로 데스크톱과 모바일 장치 모두에서 잘 작동합니다.

사용된 기술

  • HTML: 모기지 계산기의 구조를 제공합니다.
  • CSS: 시각적으로 매력적이고 사용자 친화적이도록 애플리케이션 스타일을 지정합니다.
  • JavaScript: 상호작용성을 추가하고 사용자 입력을 기반으로 모기지 계산을 수행합니다.

프로젝트 구조

프로젝트 구조 개요는 다음과 같습니다.

Mortgage-Calculator/
├── index.html
├── style.css
└── script.js
로그인 후 복사
  • index.html: 모기지 계산기의 HTML 구조가 포함되어 있습니다.
  • style.css: CSS 스타일을 포함하여 현대적이고 반응이 빠른 디자인을 만듭니다.
  • script.js: 대화형 요소를 관리하고 모기지 계산을 수행합니다.

설치

프로젝트를 시작하려면 다음 단계를 따르세요.

  1. 저장소 복제:

    git clone https://github.com/abhishekgurjar-in/Mortgage-Calculator.git
    
    로그인 후 복사
  2. 프로젝트 디렉토리 열기:

    cd Mortgage-Calculator
    
    로그인 후 복사
  3. 프로젝트 실행:

    • 모기지 계산기를 보려면 웹 브라우저에서 index.html 파일을 엽니다.

용법

  1. 웹사이트를 엽니다 웹 브라우저에서
  2. 모기지 금액, 기간, 이자율을 해당 항목에 입력합니다.
  3. 상환 옵션을 선택하세요(원금 및 이자 또는 이자만).
  4. 계산 버튼을 클릭하세요 월별 및 총 상환액을 확인하세요.
  5. 브라우저 창 크기를 조정하거나 다른 기기에서 웹사이트를 열어 반응형 디자인을 보세요.

코드 설명

HTML

index.html 파일은 입력 필드, 버튼, 결과 표시 영역을 포함하여 모기지 계산기의 구조를 정의합니다. 다음은 일부 내용입니다.

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Mortgage Calculator</title>
  <link href="https://fonts.googleapis.com/css?family=Plus+Jakarta+Sans:400,600&display=swap" rel="stylesheet">
  <link rel="stylesheet" href="style.css">
  <script src="./script.js" defer></script>
</head>
<body>
  <div class="container">
    <div class="box">
      <div class="left-box">
        <h1>Mortgage Calculator</h1>
        <p>Calculate your mortgage payments easily with this interactive tool. Enter the details below to find out your monthly and total repayments.</p>
        <div class="input-box">
          <span>£</span><input type="number" class="MortgageAmount" placeholder="Mortgage Amount">
        </div>
        <div class="input-box">
          <span>Years</span><input type="number" class="MortgageTerm" placeholder="Mortgage Term">
        </div>
        <div class="input-box">
          <span>%</span><input type="number" class="Interest" placeholder="Annual Interest Rate">
        </div>
        <div class="box-middle">
          <input type="radio" id="Repayment" name="repayment" class="option" checked>
          <label for="Repayment">Principal & Interest</label>
          <input type="radio" id="InterestOnly" name="repayment" class="option">
          <label for="InterestOnly">Interest Only</label>
        </div>
        <button class="calculate">Calculate</button>
        <div class="empty-result">
          <p>Fill out the form to see your results.</p>
        </div>
        <div class="filled-result">
          <h1>£0.00</h1>
          <h4>Total Repayment: £0.00</h4>
        </div>
      </div>
    </div>
    <div class="footer">
      <p>Made with ❤️ by Abhishek Gurjar</p>
    </div>
  </div>
</body>
</html>
로그인 후 복사

CSS

style.css 파일은 모기지 계산기의 스타일을 지정하여 매력적이고 사용하기 쉽게 만듭니다. 다음은 몇 가지 주요 스타일입니다.

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  padding: 0;
  font-family: 'Plus Jakarta Sans', sans-serif;
  font-size: 16px;
  background-color: hsl(202, 86%, 94%);
}

.container {
  margin: auto;
  max-width: 1440px;
  background-color: hsl(202, 86%, 94%);
}

.box {
  border-radius: 20px;
  background-color: whitesmoke;
  max-width: 900px;
  margin: 160px auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.left-box {
  width: 50%;
}

.left-box h1 {
  font-size: 2.5rem;
}

.left-box p {
  font-size: 1rem;
}

.input-box {
  width: 80%;
  border: 1px solid black;
  border-radius: 4px;
  display: flex;
  align-items: center;
}

.input-box span {
  width: 20px;
}

.input-box input {
  width: 70%;
  height: 100%;
  border: none;
}

.calculate {
  background-color: yellow;
  width: 50%;
  border-radius: 8px;
  height: 2.5rem;
  margin: 15px;
}

.empty-result {
  border-radius: 20px;
  padding: 10px;
  color: white;
  background-color: #1b3547;
}

.filled-result {
  display: none;
}

.footer {
  margin-top: 100px;
  text-align: center;
}

@media (max-width: 800px) {
  .box {
    flex-direction: column;
    align-items: center;
    gap: 100px;
  }
}
로그인 후 복사

자바스크립트

script.js 파일에는 사용자 입력을 기반으로 모기지 지불금을 계산하는 논리가 포함되어 있습니다. 다음은 일부 내용입니다.

document.addEventListener('DOMContentLoaded', () => {
    const calculateButton = document.querySelector('.calculate');
    const emptyResult = document.querySelector('.empty-result');
    const filledResult = document.querySelector('.filled-result');
    const mortgageAmountInput = document.querySelector('.MortgageAmount');
    const mortgageTermInput = document.querySelector('.MortgageTerm');
    const interestRateInput = document.querySelector('.Interest');
    const repaymentOption = document.querySelector('#Repayment');
    const interestOnlyOption = document.querySelector('#InterestOnly');
    const monthlyRepaymentElement = filledResult.querySelector('h1');
    const totalRepaymentElement = filledResult.querySelector('h4');

    calculateButton.addEventListener('click', () => {
      const principal = parseFloat(mortgageAmountInput.value);
      const years = parseFloat(mortgageTermInput.value);
      const annualInterestRate = parseFloat(interestRateInput.value) / 100;
      const months = years * 12;
      let monthlyRepayment;
      let totalRepayment;

      if (repaymentOption.checked) {
        const monthlyInterestRate = annualInterestRate / 12;
        monthlyRepayment = (principal * monthlyInterestRate) / (1 - Math.pow(1 + monthlyInterestRate, -months));
        totalRepayment = monthlyRepayment * months;
      } else if (interestOnlyOption.checked) {
        monthlyRepayment = (principal * annualInterestRate) / 12;
        totalRepayment = principal + (monthlyRepayment * months);
      }

      if (!isNaN(monthlyRepayment) && !isNaN(totalRepayment)) {
        monthlyRepaymentElement.textContent = `£${monthlyRepayment.toFixed(2)}`;
        totalRepaymentElement.textContent = `£${totalRepayment.toFixed(2)}`;
        emptyResult.style.display = 'none';
        filledResult.style.display = 'block';
      } else {
        alert('Please enter valid numbers for all fields.');
      }
    });
});
로그인 후 복사

라이브 데모

여기에서 모기지 계산기 프로젝트의 라이브 데모를 확인하실 수 있습니다.

결론

모기지 계산기를 만드는 것은 프론트엔드 개발 기술을 적용하여 실용적인 도구를 만드는 데 있어 귀중한 연습이었습니다. 이 프로젝트는 재무 계획에 사용할 수 있는 대화형 및 반응형 웹 애플리케이션을 만드는 방법을 보여줍니다. 여러분이 자신만의 도구를 만들고 웹 개발 기술을 향상시키는 데 영감을 주기를 바랍니다. 즐거운 코딩하세요!

크레딧

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

작가

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

위 내용은 모기지 계산기 웹사이트 구축의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿