This JavaScript code snippet helps you to create a resizable div element on a webpage. It provides functionality to change the size of a div by dragging its corners. It works by adding event listeners to the div’s resizer elements, enabling you to adjust the width and height of the div interactively. This code is helpful for creating user-friendly interfaces that require resizable elements, such as custom dashboards or design tools.
You can use this code in web development projects to create resizable elements like panels, windows, or image containers. It enhances user experience by allowing them to customize the size of elements as needed.
How to Create a Resizable Div in JavaScript
1. Begin by setting up your HTML structure for a resizable div. Include the following code within your HTML file. It creates a div element with resizer handles at its corners.
<div class='resizable'> <div class='resizers'> <div class='resizer top-left'></div> <div class='resizer top-right'></div> <div class='resizer bottom-left'></div> <div class='resizer bottom-right'></div> </div> </div>
2. To ensure proper styling and positioning, add the following CSS code to your stylesheet. You can modify the CSS rules according to your needs.
body, html { background: black; } body{ background: #000; position: relative; min-height: 720px; } .resizable { background: white; width: 100px; height: 100px; position: absolute; top: 100px; left: 100px; } .resizable .resizers{ width: 100%; height: 100%; border: 3px solid #4286f4; box-sizing: border-box; } .resizable .resizers .resizer{ width: 10px; height: 10px; border-radius: 50%; /*magic to turn square into circle*/ background: white; border: 3px solid #4286f4; position: absolute; } .resizable .resizers .resizer.top-left { left: -5px; top: -5px; cursor: nwse-resize; /*resizer cursor*/ } .resizable .resizers .resizer.top-right { right: -5px; top: -5px; cursor: nesw-resize; } .resizable .resizers .resizer.bottom-left { left: -5px; bottom: -5px; cursor: nesw-resize; } .resizable .resizers .resizer.bottom-right { right: -5px; bottom: -5px; cursor: nwse-resize; }
3. Include the following JavaScript code in your HTML file or an external script file. This code makes the div resizable. Make sure to include it just before the closing </body>
tag:
/*Make resizable div by Hung Nguyen*/ function makeResizableDiv(div) { const element = document.querySelector(div); const resizers = document.querySelectorAll(div + ' .resizer') const minimum_size = 20; let original_width = 0; let original_height = 0; let original_x = 0; let original_y = 0; let original_mouse_x = 0; let original_mouse_y = 0; for (let i = 0;i < resizers.length; i++) { const currentResizer = resizers[i]; currentResizer.addEventListener('mousedown', function(e) { e.preventDefault() original_width = parseFloat(getComputedStyle(element, null).getPropertyValue('width').replace('px', '')); original_height = parseFloat(getComputedStyle(element, null).getPropertyValue('height').replace('px', '')); original_x = element.getBoundingClientRect().left; original_y = element.getBoundingClientRect().top; original_mouse_x = e.pageX; original_mouse_y = e.pageY; window.addEventListener('mousemove', resize) window.addEventListener('mouseup', stopResize) }) function resize(e) { if (currentResizer.classList.contains('bottom-right')) { const width = original_width + (e.pageX - original_mouse_x); const height = original_height + (e.pageY - original_mouse_y) if (width > minimum_size) { element.style.width = width + 'px' } if (height > minimum_size) { element.style.height = height + 'px' } } else if (currentResizer.classList.contains('bottom-left')) { const height = original_height + (e.pageY - original_mouse_y) const width = original_width - (e.pageX - original_mouse_x) if (height > minimum_size) { element.style.height = height + 'px' } if (width > minimum_size) { element.style.width = width + 'px' element.style.left = original_x + (e.pageX - original_mouse_x) + 'px' } } else if (currentResizer.classList.contains('top-right')) { const width = original_width + (e.pageX - original_mouse_x) const height = original_height - (e.pageY - original_mouse_y) if (width > minimum_size) { element.style.width = width + 'px' } if (height > minimum_size) { element.style.height = height + 'px' element.style.top = original_y + (e.pageY - original_mouse_y) + 'px' } } else { const width = original_width - (e.pageX - original_mouse_x) const height = original_height - (e.pageY - original_mouse_y) if (width > minimum_size) { element.style.width = width + 'px' element.style.left = original_x + (e.pageX - original_mouse_x) + 'px' } if (height > minimum_size) { element.style.height = height + 'px' element.style.top = original_y + (e.pageY - original_mouse_y) + 'px' } } } function stopResize() { window.removeEventListener('mousemove', resize) } } } makeResizableDiv('.resizable')
That’s all! hopefully, you’ve successfully implemented resizable div elements on your webpage using JavaScript. You can further customize the CSS and integrate this feature into your web projects, enhancing the user experience by allowing them to resize elements effortlessly. If you have any questions or suggestions, feel free to comment below.
Similar Code Snippets:
I code and create web elements for amazing people around the world. I like work with new people. New people new Experiences.
I truly enjoy what I’m doing, which makes me more passionate about web development and coding. I am always ready to do challenging tasks whether it is about creating a custom CMS from scratch or customizing an existing system.