Skip to content
Related Articles

Related Articles

Improve Article
Save Article
Like Article

How to Create Windows 11 Interface using HTML5 ?

  • Difficulty Level : Medium
  • Last Updated : 30 Sep, 2021

In this article, we will see how to create a windows 11 interface using HTML5.

Approach: To create Windows 11 interface we will use HTML, CSS, and JavaScript. If you want to change to design you can add more functionality to it. In this article, we will divide the whole thing into three different part creating the structure, styling the structure and add functionality.

Hey geek! The constant emerging technologies in the world of web development always keeps the excitement for this subject through the roof. But before you tackle the big projects, we suggest you start by learning the basics. Kickstart your web development journey by learning JS concepts with our JavaScript Course. Now at it's lowest price ever!

Below is the step-by-step implementation of the above approach.

Step 1: In this section we will create the basic structure using HTML for the Windows 11 interface. We will give the title as “Try Windows 11” and add necessary images using <img> tag. Also add the necessary links using the <link> tag.

  • HTML Code: This code used add the images and links to structure the website. It doesn’t have any CSS property. We will create various div  using the <div> tag and give them respective class name.



<!DOCTYPE html>
    <title>Try Windows 11</title>
    <link rel="shortcut icon"
    <!-- Linking the CSS stylesheet -->
    <link rel="stylesheet" href="styles.css">
    <div class="taskbar">
        <img src=
        <img class="right" src=
    <div class="startmenu">
        <img src=
    <div class="wallpaper">
        <img src=
    <!-- Linking the external JavaScript -->
    <script src="script.js"></script>

Step 2: Styling the Structure: In the previous section, we HAVE created the structure of the windows 11 interface. Now we will add some CSS properties on it. Different classes will have different properties.

Class named taskbar will have CSS properties such as:

  1. background-color: #f3f3f3; (sets the background color of an element).
  2. width: 100%; (sets the width of the element)
  3. position: absolute; (sets the position of the element and specifies the positioning method used for the element)
  4. bottom: 0; (affects the vertical position of the positioned element).
  5. display: flex; (specifies the display behavior (the type of rendering box) of an element).
  6. z-index: 110; (specifies the stack order of an element).
  7. justify-content: center; (aligns the flexible container’s items when the items do not use all available space on the main-axis horizontally)

Class named right will have  CSS properties such as:

  1. justify-self: flex-end; (sets the way a box is justified inside its alignment container along the appropriate axis).
  2. position: absolute; (sets the position of the element and specifies the positioning method used for the element).
  3. right: 0; (affects the horizontal position of the given elements).
  4. margin: 6px 0; (creates spacing around the elements).
  5. height: 85%; (sets the height of an element).

Class named startmenu will have CSS properties such as:

  1. position: absolute; (specifies the type of positioning method used for an element).
  2. bottom: -655px; (affects the vertical position of a positioned element).
  3. width: 100%; (sets the width of an element).
  4. text-align: center; (specifies the horizontal alignment of text in an element).
  5. transition: all 0.3s ease-in; (allows to change property values smoothly, over a given duration).


    overflow: hidden;
    height: 100vh;
    background-color: #F3F3F3;
    width: 100%;
    position: absolute;
    bottom: 0;
    display: flex;
    z-index: 110;
    justify-content: center;
    justify-self: flex-end;
    position: absolute;
    right: 0;
    margin: 6px 0;
    height: 85%;
    position: absolute;
    bottom: -655px;
    width: 100%;
    text-align: center;
    transition: all 0.3s ease-in; 
.startmenu img{
    border-radius: 8px;
.wallpaper img{
    height: 900px;

Step 3: Add functionality to the website: We will write the JavaScript for the start menu and taskbar. First we will create two variables named taskbar and startmenu then inside this variable we will use the document.getElementsByClassName() method which returns a collection of all elements in the document with the specified class name, as an HTMLCollection object.

Now in the taskbar, we will add an event listener for a click that attaches an event handler to the document, and inside it, we will create an if-else statement such as if the bottom property of startmenu is 50px then update it into -655px else if it is not 50px update it into 50px. This will make the taskbar responsive.


let taskbar = document.getElementsByClassName("taskbar")[0]
let startmenu = document.getElementsByClassName("startmenu")[0]
taskbar.addEventListener("click", ()=>{
    if( == "50px"){ = "-655px"
    else{ = "50px"


My Personal Notes arrow_drop_up
Recommended Articles
Page :

Start Your Coding Journey Now!