为了账号安全,请及时绑定邮箱和手机立即绑定

仅使用 vanilla JS 制作手风琴布局时元素高度的问题

仅使用 vanilla JS 制作手风琴布局时元素高度的问题

慕少森 2022-08-04 17:27:11
我的任务是仅使用香草JS制作手风琴布局.我遇到的问题是,当我减小窗口大小并在可折叠面板内打开一个选项卡时,高度会增加,因为文本现在更大了,所以当我再次全屏时,它仍然保持窗口较小时的大小,这给了我很多空白。function slideDown(element){    element.classList.add('active');    element.style.height="auto";    element.style.display='block';    element.style.margin = "auto";    var height = element.clientHeight + "px";    element.style.height = "0px";    element.style.marginTop="16px";    element.style.marginBottom="16px";    setTimeout(() => {        element.style.height = height;    }, 0) }所以这里的问题是,每次我在手风琴中打开一个标签时,“auto”都会读取内容的高度(在较小的窗口中,内容的高度总是更大,以便将段落放入屏幕中),所以当我再次全屏显示时,它保持该大小,直到我重复此操作。我需要一个解决方案,该解决方案将根据窗口大小更改元素的高度,或者当我在可折叠面板中使用向下滑动动画时,需要另一种方法来确定内容的高度。
查看完整描述

1 回答

?
芜湖不芜

TA贡献1796条经验 获得超7个赞

如果要使此动态化,可以检测到窗口已调整大小并重新计算元素高度。

window.onresize = function(event) {
    // resize your element here
    };

请参见: https://developer.mozilla.org/en-US/docs/Web/API/Window/resize_event


查看完整回答
反对 回复 2022-08-04
  • 1 回答
  • 0 关注
  • 150 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号