ZetCode

JavaScript scrollHeight

last modified April 2, 2025

In this article, we explore the scrollHeight property in JavaScript. This property is essential for measuring the full height of an element's content, including content not visible due to overflow.

Basic Definition

The scrollHeight property returns the entire height of an element's content, including content not visible on the screen due to overflow. It is a read-only property that includes padding but not margins or borders.

Unlike clientHeight, which only measures the visible portion, scrollHeight measures all content, whether visible or not. This makes it useful for detecting overflow and implementing scroll-related features.

Basic scrollHeight Example

This example demonstrates how to get the scrollHeight of a simple div element.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Basic scrollHeight</title>
    <style>
        #content {
            height: 100px;
            overflow-y: scroll;
            border: 1px solid #ccc;
        }
    </style>
</head>
<body>

<div id="content">
    <p>This is some content.</p>
    <p>More content here.</p>
    <p>Even more content.</p>
    <p>Content continues.</p>
    <p>Final piece of content.</p>
</div>

<script>
    const element = document.getElementById('content');
    console.log('Scroll height:', element.scrollHeight);
    console.log('Client height:', element.clientHeight);
</script>

</body>
</html>

In this example, we have a div with fixed height and scrollable overflow. The JavaScript code logs both the scrollHeight (total content height) and clientHeight (visible height) to the console.

The difference between these values indicates how much content is hidden and available for scrolling. This is fundamental for understanding scroll behavior.

Detecting Content Overflow

This example shows how to use scrollHeight to detect if an element's content overflows its container.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Detecting Overflow</title>
    <style>
        #box {
            height: 150px;
            border: 1px solid black;
            padding: 10px;
            overflow-y: auto;
        }
    </style>
</head>
<body>

<div id="box">
    <p>Sample content that may or may not overflow.</p>
</div>
<p id="result"></p>

<script>
    const box = document.getElementById('box');
    const result = document.getElementById('result');
    
    if (box.scrollHeight > box.clientHeight) {
        result.textContent = 'Content overflows!';
    } else {
        result.textContent = 'Content fits perfectly.';
    }
</script>

</body>
</html>

Here we compare scrollHeight with clientHeight to determine if the content exceeds the container's visible area. The result is displayed in a paragraph element.

This technique is commonly used to implement custom scroll indicators or to dynamically adjust container sizes based on content length.

Scroll to Bottom Functionality

This example demonstrates how to automatically scroll an element to its bottom using scrollHeight.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Scroll to Bottom</title>
    <style>
        #chat {
            height: 200px;
            overflow-y: scroll;
            border: 1px solid #ddd;
            padding: 10px;
        }
    </style>
</head>
<body>

<div id="chat">
    <p>Welcome to the chat!</p>
</div>
<button onclick="addMessage()">Add Message</button>

<script>
    function addMessage() {
        const chat = document.getElementById('chat');
        const newMsg = document.createElement('p');
        newMsg.textContent = 'New message at ' + new Date().toLocaleTimeString();
        chat.appendChild(newMsg);
        
        // Scroll to bottom
        chat.scrollTop = chat.scrollHeight;
    }
</script>

</body>
</html>

In this chat-like interface, clicking the button adds a new message and automatically scrolls to the bottom. The scrollTop property is set to the scrollHeight to achieve this effect.

This pattern is essential for chat applications, log viewers, and any interface where new content should be immediately visible to users.

Infinite Scroll Detection

This example shows how to use scrollHeight to implement infinite scroll functionality.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Infinite Scroll</title>
    <style>
        #container {
            height: 300px;
            overflow-y: scroll;
            border: 1px solid #ccc;
        }
        .item {
            padding: 20px;
            border-bottom: 1px solid #eee;
        }
    </style>
</head>
<body>

<div id="container">
    <div class="item">Item 1</div>
    <div class="item">Item 2</div>
    <div class="item">Item 3</div>
</div>

<script>
    const container = document.getElementById('container');
    let itemCount = 3;
    
    container.addEventListener('scroll', function() {
        // Check if user scrolled near bottom
        if (container.scrollTop + container.clientHeight >= 
            container.scrollHeight - 50) {
            
            // Add more items
            for (let i = 0; i < 3; i++) {
                itemCount++;
                const newItem = document.createElement('div');
                newItem.className = 'item';
                newItem.textContent = 'Item ' + itemCount;
                container.appendChild(newItem);
            }
        }
    });
</script>

</body>
</html>

This example implements infinite scroll by detecting when the user scrolls near the bottom (within 50px). When triggered, it adds more items to the container.

The calculation uses scrollTop, clientHeight, and scrollHeight to determine scroll position. This is a common pattern in modern web applications.

Dynamic Content Height Adjustment

This example demonstrates how to use scrollHeight to dynamically adjust an element's height based on its content.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Dynamic Height</title>
    <style>
        #resizable {
            max-height: 300px;
            overflow-y: auto;
            border: 1px solid #999;
            transition: height 0.3s ease;
        }
        button { margin-top: 10px; }
    </style>
</head>
<body>

<div id="resizable">
    <p>Initial content.</p>
</div>
<button onclick="toggleContent()">Toggle Content</button>

<script>
    function toggleContent() {
        const box = document.getElementById('resizable');
        
        if (box.innerHTML.includes('Additional')) {
            box.innerHTML = '<p>Initial content.</p>';
        } else {
            box.innerHTML = '<p>Initial content.</p>' +
                '<p>Additional content line 1.</p>' +
                '<p>Additional content line 2.</p>' +
                '<p>Additional content line 3.</p>';
        }
        
        // Adjust height to fit content
        box.style.height = box.scrollHeight + 'px';
    }
</script>

</body>
</html>

This example shows a container that adjusts its height to fit its content when the button is clicked. The scrollHeight is used to determine the exact height needed for all content.

The transition creates a smooth animation effect. This technique is useful for collapsible panels, accordions, and other UI elements with variable content.

Source

MDN scrollHeight Documentation

In this article, we have explored the scrollHeight property in JavaScript. This property is essential for measuring content height, detecting overflow, and implementing scroll-related functionality in web applications.

Author

My name is Jan Bodnar, and I am a passionate programmer with extensive programming experience. I have been writing programming articles since 2007. To date, I have authored over 1,400 articles and 8 e-books. I possess more than ten years of experience in teaching programming.

List all JS DOM tutorials.