Saturday, October 25, 2025
HomeLanguagesJavascriptBottom Half Hidden Text Revealer on Mouse Over in CSS

Bottom Half Hidden Text Revealer on Mouse Over in CSS

In this CSS effect, the bottom half of the text is hidden, and when the user hovers over the text, some portion of the text becomes visible. This effect can be created by giving 0 brightness to text to be hidden and using the clip-path property to make it visible. JavaScript is used to get the cursor position.

Approach:

  • Create an HTML file with the name index.html.
  • Create two div elements, with the class name as upper_text and the other with the class name pointer.
  • Add styles to these two classes in CSS.
  • Make sure to give styles to both these div elements with the exact same properties i.e., size and position should be exactly the same so that both of these divs sit on top of each other.
  • Make use of the clip-path property in the upper_text div element to clip the upper half of the text.
  • Add a script tag in the index.html file.
  • Add an event listener to the document to listen for mousemove event.
  • Get the reference to the HTML element having a class name pointer.
  • Get the current position of the cursor and change the styling of the pointer element. Clip a circle of some predefined radius at the current cursor position. So that the text becomes visible for that radius.

Example: In this example, we are implementing the above-explained approach.

HTML




<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible"
                content="IE=edge">
 
    <meta name="viewport" content=
        "width=device-width, initial-scale=1.0">
 
    <style>
        * {
            padding: 0;
            margin: 0;
            box-sizing: border-box;
            overflow: hidden;
            background-color: black;
        }
         
        .upper_text,
        .pointer {
            position: fixed;
            top: 40vh;
            left: 40vw;
            width: 350px;
            color: chartreuse;
            font-size: 50px;
            cursor: all-scroll;
        }
         
        .upper_text {
            clip-path: polygon(0% 0%,
                100% 0%, 100% 50%, 0% 50%);
        }
    </style>
</head>
 
<body>
    <div class="upper_text">
        Geeks For Geeks
    </div>
 
    <div class="pointer">
        Geeks For Geeks
    </div>
    <script>
        document.addEventListener('mousemove', (e) => {
            const pointer = document.querySelector('.pointer');
             
            pointer.style.clipPath =
            `circle(30px at ${e.offsetX}px ${e.offsetY}px)`;
        });
    </script>
</body>
</html>


Output:

Whether you’re preparing for your first job interview or aiming to upskill in this ever-evolving tech landscape, neveropen Courses are your key to success. We provide top-quality content at affordable prices, all geared towards accelerating your growth in a time-bound manner. Join the millions we’ve already empowered, and we’re here to do the same for you. Don’t miss out – check it out now!
RELATED ARTICLES

Most Popular

Dominic
32361 POSTS0 COMMENTS
Milvus
88 POSTS0 COMMENTS
Nango Kala
6728 POSTS0 COMMENTS
Nicole Veronica
11892 POSTS0 COMMENTS
Nokonwaba Nkukhwana
11954 POSTS0 COMMENTS
Shaida Kate Naidoo
6852 POSTS0 COMMENTS
Ted Musemwa
7113 POSTS0 COMMENTS
Thapelo Manthata
6805 POSTS0 COMMENTS
Umr Jansen
6801 POSTS0 COMMENTS