Overflow: hidden

Set Overflow to hidden to prevent unwanted horizontal scrolling and extra whitespace in your project when elements exist outside the viewport.

layout-design
This video features an old UI. Updated version coming soon!

Sometimes elements on a page can exist outside the viewport, and an unintended side effect can be horizontal or sideways scrolling that shows extra whitespace around your design. Not all horizontal scrolling is a bad thing, but if it’s something that doesn’t work with your design, we’ll walk you through how to stop it using Overflow: hidden, responsive design, and mindful interaction setup. 

In this lesson you’ll learn:

  1. Why overflow happens
  2. How to detect overflow
  3. How to fix overflow issues

Why overflow happens

Many things can cause unwanted horizontal scrolling in your design, but generally it's caused by 1 of 2 things: 

  • The design layout has an element that is sized or positioned in a way that pushes it off the screen and outside the viewport.
  • Interaction or animations that start offscreen. For example, you have a Heading flying in from the side. When the page loads, the initial position of the Heading might be off the screen. Even though the Heading ends up in the right spot after the animation has completed, its initial position causes the page to have overflow. 
An element is positioned in a way that it’s pushed off the screen and outside the viewport, which causes overflow. 
The initial position of a Heading with an interaction applied to it starts the Heading off the screen and causes overflow. 

Unwanted horizontal scrolling can be caused by a different scenario than the 2 mentioned above, but layout and animation-related overflow tend to show up the most.

How to detect overflow

Horizontal scrolling isn’t always a bad thing. However, when testing for unwanted horizontal scrolling, be on the lookout for anything that makes your layout look or feel like the boundary (usually the right side of your design) isn't functioning as you would like. In other words, look for extra space or elements hanging off the edge of your design’s boundary as you scroll. You can check for this in the Designer and the published site

To detect in the Designer whether your project might exhibit unwanted horizontal scrolling:

  1. Open the Designer
  2. Scroll left and right to see if any elements overflow outside the viewport 
  3. Grab the edge of the Designer canvas
  4. Resize the canvas to check for responsiveness and fluidity
Note: If you're using a trackpad or a mobile device, scroll left and right — but if you’re using a mouse wheel, you can generally hold down Shift to scroll left and right.
You can grab the edge of the canvas to resize it and check for responsiveness and fluidity.

Read more about how to make your designs responsive.

To detect unwanted overflow in your published site (especially if you have interactions in place):

  1. Publish your site
  2. Check if your interactions cause unwanted whitespace to the right of your design (especially on mobile devices)
Interactions often cause unwanted whitespace, especially on mobile. 

Extra whitespace commonly occurs with interactions because even after the interaction has completed, the browser still thinks the interaction needs the extra width that was used at the start of the animation. 

How to fix overflow issues

You can stop horizontal scrolling in a few ways:

  1. Use Overflow: hidden
  2. Consider your layout and whether it’s responsive
  3. Pay attention to your interaction configuration
  4. Use alternative fixes
  5. Set Overflow: hidden on an entire page

Use Overflow: hidden

Set the parent element’s Overflow to hidden

  1. Locate the element that’s causing the unwanted horizontal scrolling (e.g., an Image element)
  2. Select its parent element (e.g., a Section)
  3. Open Style panel > Size 
  4. Set Overflow to hidden
  5. Scroll left and right to test whether this has removed your unwanted horizontal scrolling
The parent element (a Section) of an element causing overflow is shown highlighted, and set to Overflow: hidden.

When you set Overflow to hidden, this means you’re hiding elements that spill outside the parent element’s boundary. 

Any element that spills outside the parent element’s boundary (pictured as a dark rectangle around the page content) no longer appears after setting the parent element to Overflow: hidden. 
Note: Position: sticky will not work if any parent elements are set to Overflow: hidden. 

Consider your layout and whether it’s responsive

It’s always best to design responsively when creating your layout. However, a design might be laid out with a pixel-perfect width on one particular display (typically the designer’s display). This can result in unintended overflowing content when the design is viewed using other viewport sizes.

To test that you’re designing responsively:  

  1. Click the preview icon in the Designer (e.g., click the “eye” icon) 
  2. Grab the edge of the Designer canvas
  3. Resize the canvas to test responsiveness and fluidity across various viewport widths
  4. Click the desktop icon to return to the desktop breakpoint and click the preview icon to toggle out of preview mode
Grab the edge of the Designer canvas to resize it and test responsiveness and fluidity across various viewport widths.

You can also test what your designs will look like on a much larger display: 

  1. Click the canvas dimensions at the top of the Designer to open the Canvas settings
  2. Type in the exact width of the display size you’d like to preview (e.g., 2000 pixels) and press Return on your keyboard 
  3. Press any of the breakpoint buttons to exit the larger display preview
The Canvas settings modal is highlighted and width is set to 2000 pixels to demonstrate how to preview what designs will look like on larger displays.

Read more about how to make your designs responsive.

Pay attention to your interaction configuration

Let’s say you have a Heading with an interaction set on it. The Heading ends up in the correct spot after the interaction has completed, but its initial position is off the page. Because the Heading starts off the page, this initial position causes the page to get stuck in this layout, and introduces unwanted horizontal scrolling. 

To stop the unwanted horizontal scrolling that’s introduced because of this interaction:

  1. Select the Heading’s parent element (e.g., “Hero container” Div block)
  2. Set the Div block’s Overflow to hidden

This results in the Div block doing what you told it to — it hides anything hanging over its boundary. However, this causes your animation to get clipped. 

An interaction is clipped because the incorrect parent element was set to Overflow: hidden. Fix this by setting Overflow: hidden on the next parent up in the element hierarchy. 

To make sure the animation still functions as you had intended, you can remove Overflow: hidden on the Div block and instead set Overflow: hidden on the next parent up in the element hierarchy — the Section:

  1. Select the Heading’s parent element (e.g., “Hero container” Div block)
  2. Set the Div block’s Overflow to visible
  3. Select the next parent up in the hierarchy (e.g., “Hero Section”)
  4. Set the Section’s Overflow to hidden

Now the animation works as expected and your elements no longer overflow.

Use alternative fixes

You can also try the following fixes: 

  • Using percentage based widths and max widths to prevent overflow (e.g., 100% on parent elements and 100% or less on child elements)
  • Using background images for Sections instead of inline Image elements (e.g., if the image is decorative and expected to appear behind text or other content, use a background image)
  • Using X-ray mode to more easily see the boundaries of your elements causing overflow (you can toggle X-ray mode in Canvas settings)
  • Scrolling through your site in the Designer with your cursor hovering over the extra right side whitespace to identify elements causing overflow

Read more about minimum and maximum dimensions and background images.

Set Overflow: hidden on an entire page

You might wonder if you can set the topmost element’s Overflow to hidden — the Body element.

If you set Overflow to hidden on the Body, this can clip the rest of the content on the page and stop users from being able to successfully scroll through your page beyond what’s initially visible in the viewport. 

If you need to set Overflow to hidden on an entire page, an alternative is to use a Div block as a wrapper: 

  1. Open the Add panel
  2. Drag a Div block onto your page under the Body
  3. Move all your page elements inside the Div block (e.g., you’re treating the Div block as a wrapper of all your content)
  4. Select your Div block wrapper
  5. Open Style panel > Size and set Overflow to hidden (only after moving all your content into the Div block wrapper)
A Div block holding all a page’s contents is highlighted and set to Overflow: hidden. 

Aren’t you just overflowing with joy now that you’ve figured out how to solve your horizontal scrolling woes? Don’t hide it! 

Read more about Layout and Overflow settings.