Making divs user resizable with CSS

โœ๏ธ

How to make divs resize or disable the resize on textarea

14 Dec, 2020 ยท 3 min read

This article has nothing to do with browser widths and viewport media queries.

In this article, we will be talking about the resize css property.

This is one property I only came across recently, because when do you actually need the user to resize something other than a textarea box.

In my article demonstrating how the HTML <wbr> tag works, I used the resize property to showcase when the words would break.

You might find yourself in need of this one-day, so here we go, an example of how the CSS resize property works and what options it has.

The end result will look like the following GIF.

CSS Resize property

CSS resize property

To add the option we can use the following syntax:

div {
	resize: {value}
}

Where the value can be one of these:

  • none: Default, user cannot resize the element
  • both: Resize horizontal and vertical
  • horizontal: Only resize horizontally
  • vertical: Only resize vertically
  • initial: Reset back to the initial value
  • inherit: Inherit value from the parent element

To make them effective, let's create some examples:

What's really important to know is that by default, the resize code will not do anything.

This is because the default overflow value is visible, and that will disable the resize.

We can use any of these overflow values: scroll, auto, hidden.

First let's define a basic box to start with:

div {
  width: 100px;
  height: 100px;
  overflow: auto;
}

Now let's make a pink box that can resize both ways:

div.both {
  resize: both;
  background: #ef476f;
}

Perhaps we only want a horizontal resize? Check out the yellow box.

div.horizontal {
  resize: horizontal;
  background: #ffd166;
}

Over even just vertical, check out the green box

div.vertical {
  resize: vertical;
  background: #06d6a0;
}

You can see these boxes in action on the following Codepen.

See the Pen Making divs user resizable with CSS by Chris Bongers (@rebelchris) on CodePen.

CSS Removing resize attribute

There is one case where perhaps you want to remove the resize attribute, and this is with textareas.

They come with a default resize property, and we can turn this off by using the following code:

textarea {
  resize: none;
}

You can try this out on the following Codepen.

See the Pen CSS Disable resize by Chris Bongers (@rebelchris) on CodePen.

Thank you for reading, and let's connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter

Spread the knowledge with fellow developers on Twitter
Tweet this tip
Powered by Webmentions - Learn more

Read next ๐Ÿ“–

Bringing perspective to CSS

7 Aug, 2022 ยท 2 min read

Bringing perspective to CSS

Creating a 3D Cylinder shape in CSS

29 Jul, 2022 ยท 3 min read

Creating a 3D Cylinder shape in CSS