Course Content
Introduction to HTML (Structure of the Web)
0/1
Introduction to CSS (Styling the Web)
Getting Started with CSS
0/2
Introduction to JavaScript (Interactivity on the Web)
Project Presentation and Review
0/1
Protected: Web Development Bootcamp: Master HTML, CSS, and JavaScript in 3 Weeks
About Lesson

JavaScript Projects

Practical projects are a great way to reinforce the concepts you’ve learned in JavaScript. Here are two beginner-friendly projects that can help you apply your skills and gain hands-on experience.


1. Interactive Image Slider

An image slider is a great way to practice JavaScript DOM manipulation, events, and basic animations. The slider will allow users to navigate through images by clicking next/previous buttons or using automatic transitions.

Steps:

  1. Create the HTML structure for the image slider.

    • Use a container (<div>) to hold the images.
    • Add next and previous buttons to navigate the images.
  2. Style the slider with CSS.

    • Set up the images to be displayed as a horizontal line.
    • Make sure only one image is visible at a time.
  3. Write JavaScript to control the slider behavior.

    • Use event listeners for the next and previous buttons.
    • Optionally, add an automatic transition every few seconds.

HTML Example:

<div class="slider">
    <button class="prev" onclick="moveSlide(-1)">❮</button>
    <div class="slides">
        <img src="image1.jpg" class="slide">
        <img src="image2.jpg" class="slide">
        <img src="image3.jpg" class="slide">
    </div>
    <button class="next" onclick="moveSlide(1)">❯</button>
</div>

CSS Example:

.slider {
    position: relative;
    width: 500px;
    height: 300px;
    overflow: hidden;
    margin: auto;
}

.slides {
    display: flex;
    transition: transform 0.5s ease;
}

.slide {
    width: 100%;
    height: auto;
}

button {
    position: absolute;
    top: 50%;
    background: rgba(0, 0, 0, 0.5);
    color: white;
    font-size: 24px;
    border: none;
    cursor: pointer;
    padding: 10px;
}

.prev {
    left: 10px;
}

.next {
    right: 10px;
}

JavaScript Example:

let index = 0;

function moveSlide(direction) {
    const slides = document.querySelectorAll('.slide');
    const totalSlides = slides.length;

    index += direction;

    if (index < 0) {
        index = totalSlides - 1;
    } else if (index >= totalSlides) {
        index = 0;
    }

    const slidesContainer = document.querySelector('.slides');
    slidesContainer.style.transform = `translateX(-${index * 100}%)`;
}
  • Explanation:
    • moveSlide() function moves the slider by changing the transform property to shift the images horizontally.
    • The prev and next buttons call the moveSlide() function with -1 or 1 to move the slider left or right.

2. Simple To-Do List Application

Building a to-do list application is a great way to learn how to manage user input, dynamically manipulate the DOM, and handle events. This project will involve creating a list of tasks that users can add, mark as complete, and delete.

Steps:

  1. Create the HTML structure for the to-do list.

    • Include an input field for users to add tasks.
    • Include a button to add tasks to the list.
  2. Style the to-do list with CSS.

    • Create basic styles for the input field, tasks, and buttons.
  3. Write JavaScript to add interactivity.

    • Use JavaScript to add new tasks to the list.
    • Allow users to mark tasks as complete or delete tasks.

HTML Example:

<div class="todo-container">
    <input type="text" id="task-input" placeholder="Enter a new task" />
    <button onclick="addTask()">Add Task</button>

    <ul id="todo-list">
        <!-- Tasks will be added here dynamically -->
    </ul>
</div>

CSS Example:

.todo-container {
    width: 300px;
    margin: 0 auto;
    text-align: center;
}

input {
    padding: 10px;
    width: 80%;
    margin-bottom: 10px;
}

button {
    padding: 10px;
    width: 80%;
    background-color: #4CAF50;
    color: white;
    border: none;
    cursor: pointer;
}

button:hover {
    background-color: #45a049;
}

li {
    list-style-type: none;
    padding: 8px;
    margin: 5px;
    background-color: #f1f1f1;
    display: flex;
    justify-content: space-between;
}

.completed {
    text-decoration: line-through;
}

JavaScript Example:

function addTask() {
    const taskInput = document.getElementById("task-input");
    const taskText = taskInput.value.trim();

    if (taskText === "") {
        return;
    }

    const li = document.createElement("li");

    // Create the text for the task
    const task = document.createTextNode(taskText);
    li.appendChild(task);

    // Create the delete button
    const deleteButton = document.createElement("button");
    deleteButton.innerHTML = "Delete";
    deleteButton.onclick = function () {
        li.remove();
    };

    // Mark task as completed
    li.onclick = function () {
        li.classList.toggle("completed");
    };

    li.appendChild(deleteButton);

    document.getElementById("todo-list").appendChild(li);
    taskInput.value = "";
}
  • Explanation:
    • addTask() function creates a new list item (<li>) with the task and a delete button.
    • Each task item can be clicked to toggle the “completed” status, which adds or removes a strikethrough.
    • The delete button removes the task from the list.

Conclusion

These two projects; an interactive image slider and a simple to-do list are great ways to practice using JavaScript to build real-world applications. You will practice DOM manipulation, handling events, and adding dynamic content to the page. As you progress, try to add additional features like task editing in the to-do list or automatic image transitions in the slider to further improve your skills.

 

 

 

Project: Build a responsive, interactive website combining HTML, CSS, and JavaScript.