data:image/s3,"s3://crabby-images/dcb03/dcb033ccea3aff8f217a9f0cfe4a3cca85bcb533" alt="3d rectangle with medium squish."
data:image/s3,"s3://crabby-images/1ae3e/1ae3eae56a5815326fa490183d798250b1014b76" alt="3d rectangle with medium squish. 3d rectangle with medium squish."
If we use the transform property instead we can performantly animate our square on the GPU. They impact render performance too much because updating them triggers the browser to re-evaluate related element positions and sizes. The default width and height CSS properties are (along with most other properties) not suitable for animation.
data:image/s3,"s3://crabby-images/7b90a/7b90a840b58edcb47bccd344d9ced3ca4c9732ca" alt="3d rectangle with medium squish. 3d rectangle with medium squish."
This has since been partly replaced with WebGL. Pintura Image Editor used this technique on both the x and y axis to render and animate the white crop rectangle on top of the image. The file items and the drop area of the FilePond file upload library all use this technique to smoothly animate their height. Still, with a bit of trickery, you can use this to create some awesome effects. The square cannot cut off other elements, as in, overflow: hidden won’t work.A box-shadow can be done but is a bit tricky to pull off.
data:image/s3,"s3://crabby-images/e25d8/e25d88b724fca60e48299dc8fdcb85485ec4e939" alt="3d rectangle with medium squish. 3d rectangle with medium squish."
data:image/s3,"s3://crabby-images/3fadb/3fadb48a5dca3d77f411e9c8f1aa4e2cf90d45c9" alt="3d rectangle with medium squish. 3d rectangle with medium squish."
Because GPUs are very good at dealing with pixels, the transform operations are super fast. The GPU only has to deal with the pixels that present the element. This picture only consists of pixels, all other information about the element is gone. You can compare the GPU texure of an element with a picture you took of the element with your mobile phone. These updates can for instance be rotating, moving, and scaling of an element. The transform property instructs the GPU to make some last minute updates to the texture of an element before drawing it to the screen. To run performant animations we need to use the CSS transform or opacity properties. These operations are very taxing on the CPU, so to keep a website fast we should avoid triggering them as much as possible. This process is called a reflow and it will be followed by a repaint. Modifying the dimensions of one element can therefore have lots of unforeseen consequences.Ĭhanging the width and/or height of an element will trigger the browser to determine which other elements (children, siblings, or parents) are impacted by the change and how those elements should be updated. Most elements in some way impact the rendering of other elements, they push siblings to another position, or when their size is changed a parent element also changes size. In this 5 minute tutorial we’ll explore using the transform property to simulate animating the width of an element.ĭon’t Animate the Width and Height Propertiesīrowsers don’t like it when they have to calculate the positions and sizes of elements on the webpage. Unfortunately at the moment it’s a sure-fire way to get your browser to scream in agony. Being able to animate the CSS width and height properties would be super useful.
data:image/s3,"s3://crabby-images/dcb03/dcb033ccea3aff8f217a9f0cfe4a3cca85bcb533" alt="3d rectangle with medium squish."