gpt4 book ai didi

javascript - 移动动画 Accordion 中的所有元素

转载 作者:行者123 更新时间:2023-11-29 23:07:31 25 4
gpt4 key购买 nike

Animate Plus 动画的 Accordion 在 fieldset 中包含 dllegend 元素。一切正常,除了 fieldset 不会展开并且 legend 不会随其他元素一起移动。

an accordion animation example

我想平滑地调整 fieldset 高度的大小,增加相同的 dl 量。

我的 JavaScript 代码:

const accordions = Array.from(document.querySelectorAll("dl")).map(dl => ({
element: dl,
translate: 0
}))

const getButtons = accordion => Array.from(
accordion.element.getElementsByTagName("button"),
element => ({
element,
translate: 0
})
)

const timing = {
easing: "out-quartic",
duration: 400
}

const clear = element =>
Object.values(element.attributes).forEach(({ name }) =>
element.removeAttribute(name)
)

const hide = async (accordion, buttons, collapsing) => {
const objects = buttons.filter(({ translate }) => translate)
const direction = "reverse"
rotate(collapsing.previousElementSibling.lastElementChild, direction)
slide(accordion, objects)
await fold(collapsing, direction)
clear(collapsing)
}

const show = (accordion, buttons, expanding) => {
const button = expanding.previousElementSibling.lastElementChild
const index = buttons.findIndex(({ element }) => element == button)
const objects = buttons.slice(index + 1)
const { height } = expanding.getBoundingClientRect()
expanding.className = "open"
rotate(button)
slide(accordion, objects, height)
fold(expanding)
}

const slide = (accordion, array, to = 0) => {
center(accordion, to)
animate({
...timing,
elements: array.map(({ element }) => element.parentElement),
transform(index) {
const object = array[index]
const from = object.translate
object.translate = to
return [`translateY(${from}px)`, to]
}
})
}

const center = (accordion, height) => {
const from = accordion.translate
const to = Math.round(-height / 2)
accordion.translate = to
animate({
...timing,
elements: accordion.element,
transform: [`translateY(${from}px)`, to]
})
}

const fold = async (content, direction = "normal") =>
await animate({
...timing,
direction,
elements: content,
opacity: [0, 1],
transform: ["scaleY(0)", 1]
})

const rotate = ({ lastElementChild: elements }, direction = "normal") =>
animate({
elements,
direction,
easing: "out-cubic",
duration: 600,
transform: ["rotate(0turn)", 0.5]
})

const toggle = (accordion, buttons) => async ({ target }) => {
const collapsing = accordion.element.querySelector(".open")
const expanding = target.parentElement.nextElementSibling
if (collapsing) await hide(accordion, buttons, collapsing)
if (collapsing != expanding) show(accordion, buttons, expanding)
}

accordions.forEach(accordion => {
const buttons = getButtons(accordion)
buttons.forEach(
({ element }) => element.addEventListener("click", toggle(accordion, buttons))
)
})

import animate from "https://cdn.jsdelivr.net/npm/animateplus@2/animateplus.js"

My full code for an accordion can be found on CodePen:

https://codepen.io/anon/pen/ZwKMZx

最佳答案

问题都源于您有:

dd {
position: absolute;
/* more styles */
}

本质上,这使得在计算其父元素的高度时忽略该元素的高度。

我不熟悉你正在使用的库,但做了一个快速修改以删除它,当它隐藏时将最大高度设置为 0,然后将该高度设置为 scrollHeight 的动画内容的高度(即忽略 maxHeight 时内容的高度)。

https://codepen.io/anon/pen/xMXbJX

dd {
opacity: 0;
max-height: 0;
}

const fold = async (content, direction = "normal") => {
const scrollHeight = content.scrollHeight
await animate({
...timing,
direction,
elements: content,
opacity: [0, 1],
maxHeight: ['0px', scrollHeight + 'px'],
transform: ["scaleY(0)", 1]
})
}

关于javascript - 移动动画 Accordion 中的所有元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54497636/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com