BASIC EXAMPLE
<!DOCTYPE html>
<html>
<head>
<title>Page Title</title>
</head>
<body>
<h1>This is a Heading</h1>
<p>This is a paragraph.</p>
</body>
</html>
OUTPUT:
This is a Heading
This is a paragraph.
Example Explained:
- The
<!DOCTYPE html>
declaration defines that this document is an HTML5 document - The
<html>
element is the root element of an HTML page - The
<head>
element contains meta information about the HTML page - The
<title>
element specifies a title for the HTML page (which is shown in the browser’s title bar or in the page’s tab) - The
<body>
element defines the document’s body, and is a container for all the visible contents, such as headings, paragraphs, images, hyperlinks, tables, lists, etc. - The
<h1>
element defines a large heading - The
<p>
element defines a paragraph
HTML Headings
<!DOCTYPE html>
<html>
<body>
<h1>This is heading 1</h1>
<h2>This is heading 2</h2>
<h3>This is heading 3</h3>
<h4>This is heading 4</h4>
<h5>This is heading 5</h5>
<h6>This is heading 6</h6>
</body>
</html>
OUTPUT:
This is heading 1
This is heading 2
This is heading 3
This is heading 4
This is heading 5
This is heading 6
HTML Paragraphs
<!DOCTYPE html>
<html>
<body>
<p>This is a paragraph.</p>
<p>This is another paragraph.</p>
</body>
</html>
OUTPUT:
This is a paragraph.
This is another paragraph.
HTML Links
<!DOCTYPE html>
<html>
<body>
<h2>HTML Links</h2>
<p>HTML links are defined with the a tag:</p>
<a href=”#”>This is a link</a>
</body>
</html>
OUTPUT:
HTML Links
HTML links are defined with the a tag:
This is a link
HTML Images
<!DOCTYPE html>
<html>
<body>
<h2>HTML Images</h2>
<p>HTML images are defined with the img tag:</p>
<img src=”nice.jpg” alt=”nicelogo” width=”104″ height=”142″>
</body>
</html>
OUTPUT:
HTML Images
HTML images are defined with the img tag:

EXAMPLE EXPLAINED:
HTML images are defined with the <img>
tag.
The source file (src
), alternative text (alt
), width
, and height
are provided as attributes:
HTML TEXT FORMATTING
<!DOCTYPE html>
<html>
<body>
HELLO! I AM <b> bold</b><br>
HELLO! I AM <strong> strong bold</strong><br>
HELLO! I AM <i> italic</i><br>
HELLO! I AM <em>emphasized(italic)</em><br>
HELLO! I AM <u>underline</u><br>
HELLO! I AM <ins>underline(ins)</ins><br>
HELLO! I AM <strike>strikethrough</strike><br>
HELLO! I AM <del>delete text(strikethrough)</del><br>
HELLO! I AM <mark>highlight</mark><br>
HELLO! I AM superscript (a+b)<sup>2</sup>=a<sup>2</sup>+b<sup>2</sup>+2ab<br>
HELLO! I AM subscript C<sub>6</sub>H<sub>12</sub>O<sub>6</sub><br>
HELLO! I AM big<big>little bigger than normal font</big><br>
HELLO! I AM <small>little smaller than normal font</small><br>
HELLO! I AM font<font size=”7″ color=”blue” face=”jokerman”>hello NICE students</font><br>
HELLO! I AM <q> double quotation </q><br><br>
HELLO! I AM pre-formatted text
<pre>
<B>COLUMN-A COLUMN-B</B>
Computer INPUT DEVICE
CPU UTILITY SOFTWARE
RAM HARDWARE
MOUSE PROCESSOR
COMPILER MEMORY
</pre><br>
OR
<pre style=”COLOR:red;”><big><b>
*
***
*****
*******
*****
***
*
</b></big></pre>
HELLO! I AM HORIZONTAL ROW<hr color=”red” width=”500″ align=”center”><br>
HELLO! I AM LINE BREAK(BR)<br>
HELLO! I AM THE WHITE SPACE R A M<br>
HELLO! I AM TYPEWRITTER<tt>HELLO NICE STUDENT</tt><br>
</body>
</html>
OUTPUT:
HELLO! I AM bold
HELLO! I AM strong bold
HELLO! I AM italic
HELLO! I AM emphasized(italic)
HELLO! I AM underline
HELLO! I AM underline(ins)
HELLO! I AM strikethrough
HELLO! I AM delete text(strikethrough)
HELLO! I AM highlight
HELLO! I AM superscript (a+b)2=a2+b2+2ab
HELLO! I AM subscript C6H12O6
HELLO! I AM biglittle bigger than normal font
HELLO! I AM little smaller than normal font
HELLO! I AM fonthello NICE students
HELLO! I AM double quotation
HELLO! I AM pre-formatted text
COLUMN-A COLUMN-B
Computer INPUT DEVICE
CPU UTILITY SOFTWARE
RAM HARDWARE
MOUSE PROCESSOR
COMPILER MEMORY
OR
*
***
*****
*******
*****
***
*
HELLO! I AM HORIZONTAL ROW
HELLO! I AM LINE BREAK(BR)
HELLO! I AM THE WHITE SPACE R A M
HELLO! I AM TYPEWRITTERHELLO NICE STUDENT
CLICK ME FOR OUTPUT
Front Page html+css
<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<meta name=”viewport” content=”width=device-width, initial-scale=1.0″>
<title>Nice Institutes</title>
<style>
#blu{
color: blue;
font-size: 300%;
}
#red{
color: red;
}
#im{
margin-left: 40%;
}
#s24{
color: purple;
}
pre{
font-size: 200%;
margin-left: 10%;
color: darkturquoise;
}
#maa{
color: red;
}
#tab{
font-size: 200%;
margin-left: 5%;
}
.cls{
text-align: center;
}
</style>
</head>
<body>
<h1 id=”blu” class=”cls”>
<b >
A Project Report on Html For Beginners
</b>
</h1><br><br>
<img id=”im”src=”https://niceinstitutes.com/wp-content/uploads/2022/11/cropped-WhatsApp-Image-2022-11-15-at-6.03.44-PM-2.jpeg” width=”200″ height=”200″>
<h1 id=”red” class=”cls”>
<b >
NATIONAL INSTITUTE OF COMPUTER EDUCATION
</b>
</h1><br><br>
<h1 id=”s24″ class=”cls”>
<b>
Session 2024-25
</b>
</h1><br><br>
<pre>
Prepared By Under Guaidanc Of
Name:- Nice Student Name:- Nice Faculty
Batch No :- 04/24 Designation: Faculty Designation
</pre><br><br>
<h1 id=”maa” class=”cls”>
<b>
Under Maa Manikeswari University
</b>
</h1><br><br>
<table id=”tab” border=”2″ class=”cls”>
<tr >
<th><img src=”https://kuwebsite.s3.amazonaws.com/kuwebsite/img/mmu-logo-min.jpg” width=”200″ height=”200″></th>
<th colspan=”20″>NH26, Bazarpada, Bhawanipatna, Odisha 766001<br> 09937816855</th>
</tr>
</table>
</body>
</html>
id card
<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<meta name=”viewport” content=”width=device-width, initial-scale=1.0″>
<title>ID Card Maker</title>
<style>
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 0;
background-color: #f4f4f9;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
}
.container {
text-align: center;
max-width: 400px;
padding: 40px;
border: 10px solid #ddd;
border-radius: 30px;
background-color: white;
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}
h1 {
color: #333;
}
.id-card {
margin-top: 20px;
padding: 10px;
border: 2px solid #333;
border-radius: 8px;
width: 300px;
height: 180px;
text-align: left;
background-color: #f7f7f7;
}
.id-card img {
border-radius: 50%;
width: 100px;
height: 100px;
float: left;
margin-right: 30px;
margin-top: 30px;
}
.id-card .details {
padding-top: 10px;
}
.input-group {
margin-bottom: 10px;
}
.input-group label {
display: block;
margin-bottom: 5px;
font-weight: bold;
}
.input-group input {
width: 100%;
padding: 8px;
border: 1px solid #ccc;
border-radius: 5px;
}
button {
padding: 10px 20px;
background-color: #5cb85c;
color: white;
border: none;
border-radius: 5px;
cursor: pointer;
}
button:hover {
background-color: #4cae4c;
}
</style>
</head>
<body>
<div class=”container”>
<img src=”” width=”50″>
<h1>ID Card Maker</h1>
<div class=”input-group”>
<label for=”name”>Name:</label>
<input type=”text” id=”name” placeholder=”Enter your name”>
</div>
<div class=”input-group”>
<label for=”position”>Position:</label>
<input type=”text” id=”position” placeholder=”Enter your position”>
</div>
<div class=”input-group”>
<label for=”profile”>Profile Image URL:</label>
<input type=”text” id=”profile” placeholder=”Enter image URL”>
</div>
<button onclick=”generateID()”>Generate ID Card</button>
<div class=”id-card” id=”id-card” style=”display: none;”>
<img id=”card-image” src=”” alt=”Profile Picture”>
<div class=”details”>
<p><strong>Name:</strong> <span id=”card-name”></span></p>
<p><strong>Position:</strong> <span id=”card-position”></span></p>
</div>
</div>
</div>
<script>
function generateID() {
const name = document.getElementById(‘name’).value;
const position = document.getElementById(‘position’).value;
const profile = document.getElementById(‘profile’).value;
if (name && position && profile) {
document.getElementById(‘card-name’).textContent = name;
document.getElementById(‘card-position’).textContent = position;
document.getElementById(‘card-image’).src = profile;
document.getElementById(‘id-card’).style.display = ‘block’;
} else {
alert(‘Please fill in all fields!’);
}
}
</script>
</body>
</html>
Output 1

Output 2

Simple Calculator
<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<meta name=”viewport” content=”width=device-width, initial-scale=1.0″>
<title>Simple Calculator by Nice</title>
<style>
body {
font-family: Arial, sans-serif;
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
margin: 0;
background-color: #f4f4f9;
}
.calculator {
background-color: #ac99c2;
border-radius: 10px;
box-shadow: 0 0 15px rgba(0, 0, 0, 0.1);
padding: 20px;
width: 260px;
}
#display {
width: 93%;
height: 50px;
font-size: 24px;
text-align: right;
margin-bottom: 10px;
padding: 10px;
border: 1px solid #ccc;
border-radius: 5px;
}
.buttons {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 10px;
}
button {
font-size: 20px;
padding: 20px;
border: none;
background-color: #f0f0f0;
cursor: pointer;
border-radius: 5px;
transition: background-color 0.3s;
}
button:hover {
background-color: #ddd;
}
button:active {
background-color: #bbb;
}
</style>
</head>
<body>
<div class=”calculator”>
<input type=”text” id=”display” disabled />
<div class=”buttons”>
<img src=”” width=”50″>
<img src=”” width=”50″>
<img src=”” width=”50″>
<button onclick=”clearDisplay()”>C</button>
<button onclick=”appendToDisplay(‘1’)”>1</button>
<button onclick=”appendToDisplay(‘2’)”>2</button>
<button onclick=”appendToDisplay(‘3’)”>3</button>
<button onclick=”appendToDisplay(‘+’)”>+</button>
<button onclick=”appendToDisplay(‘4’)”>4</button>
<button onclick=”appendToDisplay(‘5’)”>5</button>
<button onclick=”appendToDisplay(‘6’)”>6</button>
<button onclick=”appendToDisplay(‘-‘)”>-</button>
<button onclick=”appendToDisplay(‘7’)”>7</button>
<button onclick=”appendToDisplay(‘8’)”>8</button>
<button onclick=”appendToDisplay(‘9’)”>9</button>
<button onclick=”appendToDisplay(‘*’)”>*</button>
<button onclick=”appendToDisplay(‘0’)”>0</button>
<button onclick=”appendToDisplay(‘.’)”>.</button>
<button onclick=”calculateResult()”>=</button>
<button onclick=”appendToDisplay(‘/’)”>/</button>
</div>
</div>
<script>
let display = document.getElementById(‘display’);
function appendToDisplay(value) {
display.value += value;
}
function clearDisplay() {
display.value = ”;
}
function calculateResult() {
try {
display.value = eval(display.value); // Evaluate the expression
} catch (e) {
display.value = ‘Error’;
}
}
</script>
</body>
</html>
OutPut
External css example
index.html
<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<meta name=”viewport” content=”width=device-width, initial-scale=1.0″>
<title>Movie Booking</title>
<link rel=”stylesheet” href=”/css/style.css”>
</head>
<body>
<header>
<h1>Movie Booking</h1>
</header>
<main>
<section class=”booking-form”>
<h1>Book Your Movie Tickets</h1>
<form id=”bookingForm”>
<h1>Select Movie:</h1>
<select id=”movie” name=”movie”>
<option value=”avengers”>Avengers: Endgame</option>
<option value=”joker”>Joker</option>
<option value=”inception”>Inception</option>
</select>
<h1>Select Date:</h1>
<input type=”date” id=”date” name=”date” required>
<h1>Number of Tickets:</h1>
<input type=”number” id=”seats” name=”seats” min=”1″ max=”10″ required>
<button type=”submit”>Book Now</button>
</form>
</section>
</main>
<h1 id=”ram”>Nice Institutes</h1>
</body>
</html>
Style.css
/* General Styles */
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 0;
background-color: #f4f4f4;
text-align: center;
}
/* Header */
header {
background-color: #333;
color: white;
padding: 1rem 0;
}
/* Main Section */
main {
display: flex;
justify-content: center;
align-items: center;
height: 80vh;
}
/* Booking Form */
.booking-form {
background: white;
padding: 20px;
border-radius: 8px;
box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
width: 300px;
}
h1 {
font-size: 20px;
margin-bottom: 10px;
}
select, input, button {
width: 100%;
padding: 10px;
margin-top: 5px;
border: 1px solid #ccc;
border-radius: 5px;
}
button {
background-color: #28a745;
color: white;
font-size: 1rem;
border: none;
cursor: pointer;
margin-top: 15px;
}
button:hover {
background-color: #218838;
}
#ram {
background-color: #333;
color: white;
padding: 1rem;
position: fixed;
width: 100%;
bottom: 0;
}
Tic-Tac-Toe – Classic two-player game
index.html
<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<meta name=”viewport” content=”width=device-width, initial-scale=1.0″>
<title>Tic-Tac-Toe</title>
<link rel=”stylesheet” href=”style.css”>
</head>
<body>
<h1>Tic-Tac-Toe</h1>
<p id=”status”>Player X’s turn</p>
<div class=”board”>
<div class=”cell” onclick=”makeMove(0)”></div>
<div class=”cell” onclick=”makeMove(1)”></div>
<div class=”cell” onclick=”makeMove(2)”></div>
<div class=”cell” onclick=”makeMove(3)”></div>
<div class=”cell” onclick=”makeMove(4)”></div>
<div class=”cell” onclick=”makeMove(5)”></div>
<div class=”cell” onclick=”makeMove(6)”></div>
<div class=”cell” onclick=”makeMove(7)”></div>
<div class=”cell” onclick=”makeMove(8)”></div>
</div>
<button onclick=”resetGame()”>Restart</button>
<script src=”script.js”></script>
</body>
</html>
style.css
body {
text-align: center;
font-family: Arial, sans-serif;
}
.board {
display: grid;
grid-template-columns: repeat(3, 100px);
grid-template-rows: repeat(3, 100px);
gap: 5px;
justify-content: center;
margin: 20px auto;
}
.cell {
width: 100px;
height: 100px;
display: flex;
align-items: center;
justify-content: center;
font-size: 2em;
background-color: lightgray;
border: 2px solid black;
cursor: pointer;
}
.cell:hover {
background-color: gray;
}
button {
font-size: 18px;
padding: 10px 20px;
margin-top: 20px;
cursor: pointer;
}
script.js
// Tic-Tac-Toe Game Logic
let board = [“”, “”, “”, “”, “”, “”, “”, “”, “”];
let currentPlayer = “X”;
let gameActive = true;
// Function to handle player move
function makeMove(index) {
if (board[index] === “” && gameActive) {
board[index] = currentPlayer;
document.getElementsByClassName(“cell”)[index].innerText = currentPlayer;
if (checkWinner()) {
document.getElementById(“status”).innerText = `Player ${currentPlayer} Wins!`;
gameActive = false;
return;
}
if (!board.includes(“”)) {
document.getElementById(“status”).innerText = “It’s a Draw!”;
gameActive = false;
return;
}
currentPlayer = currentPlayer === “X” ? “O” : “X”;
document.getElementById(“status”).innerText = `Player ${currentPlayer}’s turn`;
}
}
// Function to check for a winner
function checkWinner() {
const winPatterns = [
[0, 1, 2], [3, 4, 5], [6, 7, 8], // Rows
[0, 3, 6], [1, 4, 7], [2, 5, 8], // Columns
[0, 4, 8], [2, 4, 6] // Diagonals
];
return winPatterns.some(pattern => {
const [a, b, c] = pattern;
return board[a] && board[a] === board[b] && board[a] === board[c];
});
}
// Function to reset the game
function resetGame() {
board = [“”, “”, “”, “”, “”, “”, “”, “”, “”];
gameActive = true;
currentPlayer = “X”;
document.getElementById(“status”).innerText = “Player X’s turn”;
document.querySelectorAll(“.cell”).forEach(cell => {
cell.innerText = “”;
});
}
Snake Game – A classic game where the snake eats food and grows.
Create index.html
<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<meta name=”viewport” content=”width=device-width, initial-scale=1.0″>
<title>Snake Game</title>
<link rel=”stylesheet” href=”style.css”>
</head>
<body>
<h1>Snake Game</h1>
<p>Use Arrow Keys to Move</p>
<canvas id=”gameCanvas”></canvas>
<p id=”score”>Score: 0</p>
<script src=”script.js”></script>
</body>
</html>
Create style.css
body {
text-align: center;
font-family: Arial, sans-serif;
}
canvas {
border: 3px solid black;
background-color: lightgray;
}
Create script.js
// Get the canvas and context
const canvas = document.getElementById(“gameCanvas”);
const ctx = canvas.getContext(“2d”);
// Set canvas size
canvas.width = 400;
canvas.height = 400;
// Snake properties
let snake = [{ x: 200, y: 200 }];
let direction = “RIGHT”;
let food = spawnFood();
let score = 0;
let gameSpeed = 100;
// Handle keypress for movement
document.addEventListener(“keydown”, (event) => {
if (event.key === “ArrowUp” && direction !== “DOWN”) direction = “UP”;
else if (event.key === “ArrowDown” && direction !== “UP”) direction = “DOWN”;
else if (event.key === “ArrowLeft” && direction !== “RIGHT”) direction = “LEFT”;
else if (event.key === “ArrowRight” && direction !== “LEFT”) direction = “RIGHT”;
});
// Game loop
function gameLoop() {
moveSnake();
if (checkCollision()) {
alert(“Game Over! Your Score: ” + score);
resetGame();
return;
}
drawGame();
setTimeout(gameLoop, gameSpeed);
}
// Move snake
function moveSnake() {
let head = { …snake[0] };
if (direction === “UP”) head.y -= 20;
if (direction === “DOWN”) head.y += 20;
if (direction === “LEFT”) head.x -= 20;
if (direction === “RIGHT”) head.x += 20;
snake.unshift(head);
// Check if snake eats food
if (head.x === food.x && head.y === food.y) {
score += 10;
document.getElementById(“score”).innerText = “Score: ” + score;
food = spawnFood();
} else {
snake.pop();
}
}
// Check collision (wall or self)
function checkCollision() {
let head = snake[0];
// Wall collision
if (head.x < 0 || head.x >= canvas.width || head.y < 0 || head.y >= canvas.height) {
return true;
}
// Self-collision
for (let i = 1; i < snake.length; i++) {
if (snake[i].x === head.x && snake[i].y === head.y) {
return true;
}
}
return false;
}
// Draw snake, food, and game area
function drawGame() {
ctx.clearRect(0, 0, canvas.width, canvas.height);
// Draw food
ctx.fillStyle = “red”;
ctx.fillRect(food.x, food.y, 20, 20);
// Draw snake
ctx.fillStyle = “green”;
snake.forEach(segment => {
ctx.fillRect(segment.x, segment.y, 20, 20);
});
}
// Spawn food at random location
function spawnFood() {
let x = Math.floor(Math.random() * (canvas.width / 20)) * 20;
let y = Math.floor(Math.random() * (canvas.height / 20)) * 20;
return { x, y };
}
// Reset game
function resetGame() {
snake = [{ x: 200, y: 200 }];
direction = “RIGHT”;
score = 0;
document.getElementById(“score”).innerText = “Score: 0”;
food = spawnFood();
gameLoop();
}
// Start the game
gameLoop();
Dino Game google
index.html
<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<meta name=”viewport” content=”width=device-width, initial-scale=1.0″>
<title>Dino Game</title>
<link rel=”stylesheet” href=”style.css”>
</head>
<body>
<h1>Chrome Dino Game</h1>
<p>Press **Spacebar** to jump</p>
<div id=”game”>
<img id=”dino” src=”swapnil_dinaswar.png” alt=”Swapnil Dinaswar”>
<img id=”cactus” src=”swapnil_cactus.png” alt=”Swapnil Cactus”>
</div>
<p id=”score”>Score: 0</p>
<script src=”script.js”></script>
</body>
</html>
style.css
* {
margin: 0;
padding: 0;
box-sizing: border-box;
font-family: Arial, sans-serif;
}
body {
text-align: center;
background-color: #f4f4f4;
}
#game {
position: relative;
width: 600px;
height: 200px;
border: 2px solid black;
margin: 50px auto;
background-color: white;
overflow: hidden;
}
#dino {
width: 50px;
position: absolute;
bottom: 0;
left: 50px;
}
#cactus {
width: 30px;
position: absolute;
bottom: 0;
right: -20px;
animation: moveCactus 2s linear infinite;
}
@keyframes moveCactus {
0% { right: -20px; }
100% { right: 600px; }
}
.jump {
animation: jump 0.5s linear;
}
@keyframes jump {
0% { bottom: 0; }
50% { bottom: 80px; }
100% { bottom: 0; }
}
#score {
font-size: 20px;
margin-top: 10px;
}
script.js
let dino = document.getElementById(“dino”);
let cactus = document.getElementById(“cactus”);
let score = document.getElementById(“score”);
let counter = 0;
// Jump function
document.addEventListener(“keydown”, function(event) {
if (event.code === “Space”) {
if (!dino.classList.contains(“jump”)) {
dino.classList.add(“jump”);
setTimeout(function() {
dino.classList.remove(“jump”);
}, 500);
}
}
});
// Collision detection
setInterval(function() {
let dinoTop = parseInt(window.getComputedStyle(dino).getPropertyValue(“bottom”));
let cactusLeft = parseInt(window.getComputedStyle(cactus).getPropertyValue(“right”));
// If the dino hits the cactus
if (cactusLeft > 520 && cactusLeft < 570 && dinoTop < 40) {
alert(“Game Over! Score: ” + counter);
counter = 0;
} else {
counter++;
score.innerText = “Score: ” + counter;
}
}, 100);
find si html+css+js
<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<meta name=”viewport” content=”width=device-width, initial-scale=1.0″>
<title>Simple Interest Calculator</title>
<style>
/* General styling */
body {
font-family: Arial, sans-serif;
text-align: center;
padding: 0;
margin: 0;
background-color: #f0f8ff;
color: #333;
overflow: hidden;
}
/* Main container styling */
.container {
background-color: white;
padding: 30px;
border-radius: 16px;
box-shadow: 0 0 20px rgba(0, 0, 0, 0.3);
max-width: 600px;
margin: 60px auto;
position: relative;
z-index: 10;
}
/* Input and button styling */
input, button {
width: 100%;
padding: 12px;
margin: 10px 0;
border: 1px solid #ccc;
border-radius: 8px;
font-size: 16px;
box-sizing: border-box;
}
button {
background-color: #007bff;
color: white;
cursor: pointer;
font-weight: bold;
transition: background-color 0.3s ease;
}
button:hover {
background-color: #0056b3;
}
/* Result section styling */
.result-page {
display: none;
padding: 30px;
border-radius: 16px;
background-color: white;
box-shadow: 0 0 20px rgba(0, 123, 255, 0.3);
position: relative;
}
.result-content {
padding: 20px;
background-color: #e6f7ff;
border-radius: 10px;
border: 1px solid #91d5ff;
box-shadow: 0 0 10px rgba(0, 123, 255, 0.2);
}
/* Confetti animation */
#confettiCanvas {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
pointer-events: none;
z-index: 5;
display: none;
opacity: 1;
transition: opacity 2s ease-out;
}
/* Back button */
.back-btn {
background-color: #ff5722;
color: white;
margin-top: 15px;
}
.back-btn:hover {
background-color: #e64a19;
}
</style>
</head>
<body>
<!– Calculator section –>
<div class=”container” id=”calculatorPage”>
<h1>💰 Simple Interest Calculator 💰</h1>
<label for=”principal”>Principal Amount (₹ in rupees):</label>
<input type=”number” id=”principal” placeholder=”Enter principal amount” required>
<label for=”rate”>Rate of Interest (% per month):</label>
<input type=”number” id=”rate” placeholder=”Enter interest rate per month” required>
<label for=”time”>Time (in years):</label>
<input type=”number” id=”time” placeholder=”Enter time in years” required>
<button onclick=”calculateInterest()”>Calculate Interest</button>
</div>
<!– Result section –>
<div class=”container result-page” id=”resultPage”>
<canvas id=”confettiCanvas”></canvas>
<h2>🎉 Calculation Result 🎉</h2>
<div class=”result-content” id=”resultContent”></div>
<button class=”back-btn” onclick=”goBack()”>← Back to Home</button>
</div>
<script>
// Calculate simple interest
function calculateInterest() {
let principal = parseFloat(document.getElementById(“principal”).value);
let rate = parseFloat(document.getElementById(“rate”).value);
let timeInYears = parseFloat(document.getElementById(“time”).value);
let timeInMonths = timeInYears * 12;
if (principal > 0 && rate > 0 && timeInYears > 0) {
let interest = (principal * rate * timeInMonths) / 100;
let totalAmount = principal + interest;
document.getElementById(“resultContent”).innerHTML = `
<p><strong>💸 Principal Amount:</strong> ₹${principal.toFixed(2)}</p>
<p><strong>📅 Rate of Interest per Month:</strong> ${rate}%</p>
<p><strong>🕰️ Time Period:</strong> ${timeInYears} years (${timeInMonths} months)</p>
<hr>
<p><strong>✅ Simple Interest:</strong> ₹${interest.toFixed(2)}</p>
<p><strong>💰 Total Amount after ${timeInYears} years:</strong> ₹${totalAmount.toFixed(2)}</p>
`;
document.getElementById(“calculatorPage”).style.display = “none”;
document.getElementById(“resultPage”).style.display = “block”;
startConfetti();
} else {
alert(“❌ Please enter valid positive values for all fields.”);
}
}
// Go back to calculator
function goBack() {
document.getElementById(“principal”).value = ”;
document.getElementById(“rate”).value = ”;
document.getElementById(“time”).value = ”;
document.getElementById(“calculatorPage”).style.display = “block”;
document.getElementById(“resultPage”).style.display = “none”;
}
// Confetti effect
let canvas = document.getElementById(“confettiCanvas”);
let ctx = canvas.getContext(“2d”);
let confetti = [];
function startConfetti() {
canvas.style.display = “block”;
canvas.style.opacity = 1;
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
confetti = [];
for (let i = 0; i < 200; i++) {
confetti.push({
x: Math.random() * canvas.width,
y: Math.random() * canvas.height,
radius: Math.random() * 4 + 2,
color: `hsl(${Math.random() * 360}, 100%, 70%)`,
speedY: Math.random() * 3 + 2
});
}
requestAnimationFrame(drawConfetti);
setTimeout(() => {
canvas.style.opacity = 0;
setTimeout(stopConfetti, 2000); // Fade out over 2 seconds
}, 2000);
}
function drawConfetti() {
ctx.clearRect(0, 0, canvas.width, canvas.height);
confetti.forEach(p => {
ctx.beginPath();
ctx.arc(p.x, p.y, p.radius, 0, Math.PI * 2);
ctx.fillStyle = p.color;
ctx.fill();
p.y += p.speedY;
if (p.y > canvas.height) p.y = 0;
});
requestAnimationFrame(drawConfetti);
}
function stopConfetti() {
canvas.style.display = “none”;
ctx.clearRect(0, 0, canvas.width, canvas.height);
}
window.addEventListener(“resize”, () => {
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
});
</script>
</body>
</html>