Table of Contents
Use the Web Animations API to be native
Animation effects of elements
HTML structure
Accordion class
Set up accordion
Notice
Summarize
Home Web Front-end CSS Tutorial How to Animate the Details Element Using WAAPI

How to Animate the Details Element Using WAAPI

Apr 01, 2025 am 04:14 AM

Use the Web Animations API to be native<details></details> Animation effects of elements

One of the most common animation requirements on a website is the accordion-style expansion and closing effect. Interestingly, jQuery's slideDown() function already existed as early as the first version in 2006.

This article will explain how to use the Web Animations API as native<details></details> Animate elements.

HTML structure

First, let's look at the HTML tag structure required to implement this animation.

<details></details> An element requires one<summary></summary> element.<summary></summary> It is something visible when the accordion is folded.<details></details> All other elements within are part of the content inside the accordion. To facilitate the implementation of animation effects, we wrap them in one

middle.
<details>
  <summary>Accordion title</summary>
  <div class="content">
    <p>
      Lorem ipsum dolor sit amet, consistetur apisicing elit. Modi unde, ex rem voluptates autem aliquid veniam quis temporibus repudiandae illo, nostrum, pariatur quae! At animi modi dignissimos corrupti placeat voluptatum!
    </p>
  </div>
</details>
Copy after login

Accordion class

To improve the reusability of the code, we should create an Accordion class. This way we can use every<details></details> Call new Accordion() on the element.

 class Accordion {
  constructor(el) {}
  onClick(e) {}
  shrink() {}
  open() {}
  expand() {}
  onAnimationFinish(open) {}
}
Copy after login

constructor()

The constructor is used to store the data required for each accordion.

 constructor(el) {
  this.el = el;
  this.summary = el.querySelector('summary');
  this.content = el.querySelector('.content');
  this.animation = null;
  this.isClosing = false;
  this.isExpanding = false;
  this.summary.addEventListener('click', (e) => this.onClick(e));
}
Copy after login

onClick()

In the onClick() function, we check if the element is being animate (close or expand). If the user clicks on the accordion while the element is being animate, we need to do this check. If the click speed is too fast, we don't want the accordion to jump from fully expanded to completely closed.<details></details> When an element is opened, the browser will add an open property to it. We can get the value of this property through this.el.open .

 onClick(e) {
  e.preventDefault();
  this.el.style.overflow = 'hidden';
  if (this.isClosing || !this.el.open) {
    this.open();
  } else if (this.isExpanding || this.el.open) {
    this.shrink();
  }
}
Copy after login

shrink()

This shrink() function uses WAAPI's .animate() function. You can read the MDN documentation for more information. WAAPI is very similar to CSS @keyframes . We need to define the start and end keyframes of the animation. In this example, we only need two keyframes, the first is the current height of the element and the second is the height after the accordion is closed. The current height is stored in the startHeight variable. Close height is stored in the endHeight variable, equal to<summary></summary> height.

 shrink() {
  this.isClosing = true;
  const startHeight = `${this.el.offsetHeight}px`;
  const endHeight = `${this.summary.offsetHeight}px`;
  if (this.animation) {
    this.animation.cancel();
  }
  this.animation = this.el.animate({
    height: [startHeight, endHeight]
  }, {
    duration: 400,
    ease: 'ease-out'
  });
  this.animation.onfinish = () => this.onAnimationFinish(false);
  this.animation.oncancel = () => this.isClosing = false;
}
Copy after login

open()

The open() function is called when we want to expand the accordion. This function currently does not control the accordion animation. First, we calculate<details></details> The height of the element and apply it to the element using inline style. Once done, we can set its open property to make the content visible, but since we set overflow: hidden and fixed height for the element, the content is still hidden. Then, we wait for the next frame to call the expand() function and create an animation for the element.

 open() {
  this.el.style.height = `${this.el.offsetHeight}px`;
  this.el.open = true;
  window.requestAnimationFrame(() => this.expand());
}
Copy after login

expand()

The expand() function is similar to the shrink() function, but it does not animation from the current height to the close height, but from the height of the element to the end height. The end height is equal to<summary></summary> height plus the height of the internal content.

 expand() {
  this.isExpanding = true;
  const startHeight = `${this.el.offsetHeight}px`;
  const endHeight = `${this.summary.offsetHeight this.content.offsetHeight}px`;
  if (this.animation) {
    this.animation.cancel();
  }
  this.animation = this.el.animate({
    height: [startHeight, endHeight]
  }, {
    duration: 400,
    ease: 'ease-out'
  });
  this.animation.onfinish = () => this.onAnimationFinish(true);
  this.animation.oncancel = () => this.isExpanding = false;
}
Copy after login

onAnimationFinish()

This function is called when the animation is collapsed or expanded. As you can see, there is a parameter open , set to true when the accordion is turned on, allowing us to set the open HTML attribute on the element, as it is no longer handled by the browser.

 onAnimationFinish(open) {
  this.el.open = open;
  this.animation = null;
  this.isClosing = false;
  this.isExpanding = false;
  this.el.style.height = this.el.style.overflow = '';
}
Copy after login

Set up accordion

We did most of the code!

All that's left is for each of the HTML<details></details> Elements use our Accordion class. To do this, we use<details></details> querySelectorAll on the tag and create a new Accordion instance for each element.

 document.querySelectorAll('details').forEach((el) => {
  new Accordion(el);
});
Copy after login

Notice

To calculate the close height and the open height, we need to ensure<summary></summary> Always have the same height as the content.

For example, don't try<summary></summary> Add padding when turned on, as this may cause jumps during the animation process. The same goes for internal content – ​​it should have a fixed height, and we should avoid content with height changes during the animation opening.

Also, don't<summary></summary> Add margins between contents, as it does not calculate height keyframes. Instead, use padding directly on the content to add some spacing.

Summarize

That's it, we created a beautiful accordion animation using JavaScript without any libraries required!

How to Animate the Details Element Using WAAPI

Please note that the image path /uploads/20250331/174338369667e9ec90190a3.jpg needs to be replaced with the actual image path. I can't access or process the image file, so I can only keep the original format.

The above is the detailed content of How to Animate the Details Element Using WAAPI. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Working With GraphQL Caching Working With GraphQL Caching Mar 19, 2025 am 09:36 AM

If you’ve recently started working with GraphQL, or reviewed its pros and cons, you’ve no doubt heard things like “GraphQL doesn’t support caching” or

Making Your First Custom Svelte Transition Making Your First Custom Svelte Transition Mar 15, 2025 am 11:08 AM

The Svelte transition API provides a way to animate components when they enter or leave the document, including custom Svelte transitions.

Show, Don't Tell Show, Don't Tell Mar 16, 2025 am 11:49 AM

How much time do you spend designing the content presentation for your websites? When you write a new blog post or create a new page, are you thinking about

Building an Ethereum app using Redwood.js and Fauna Building an Ethereum app using Redwood.js and Fauna Mar 28, 2025 am 09:18 AM

With the recent climb of Bitcoin’s price over 20k $USD, and to it recently breaking 30k, I thought it’s worth taking a deep dive back into creating Ethereum

What the Heck Are npm Commands? What the Heck Are npm Commands? Mar 15, 2025 am 11:36 AM

npm commands run various tasks for you, either as a one-off or a continuously running process for things like starting a server or compiling code.

How do you use CSS to create text effects, such as text shadows and gradients? How do you use CSS to create text effects, such as text shadows and gradients? Mar 14, 2025 am 11:10 AM

The article discusses using CSS for text effects like shadows and gradients, optimizing them for performance, and enhancing user experience. It also lists resources for beginners.(159 characters)

Creating Your Own Bragdoc With Eleventy Creating Your Own Bragdoc With Eleventy Mar 18, 2025 am 11:23 AM

No matter what stage you’re at as a developer, the tasks we complete—whether big or small—make a huge impact in our personal and professional growth.

Let's use (X, X, X, X) for talking about specificity Let's use (X, X, X, X) for talking about specificity Mar 24, 2025 am 10:37 AM

I was just chatting with Eric Meyer the other day and I remembered an Eric Meyer story from my formative years. I wrote a blog post about CSS specificity, and

See all articles