gpt4 book ai didi

javascript - 扩展高度以包括绝对定位的 child

转载 作者:太空狗 更新时间:2023-10-29 13:19:30 25 4
gpt4 key购买 nike

我正在为 CMS 构建一个 html/javascript 主题设计器。元素是绝对定位的,可以通过鼠标移动/调整大小,和/或包含可编辑的文本,其高度可以由行数决定。但是,我遇到了一个问题,即父元素的高度不会扩展以包含其绝对定位的子元素。

最小代码(也在 JSFiddle here 上):

<style>
div.layer { position: absolute }
div.layer1 { width: 400px; border: 1px solid #ccc }
div.layer2 { top: 15px; left: 100px; width: 100px; border: 1px solid blue }
</style>
<div class="layer layer1">container should expand to the bottom of the child.
<div class="layer layer2" contentEditable>Child with<br/>editable text.</div>
</div>

纯 CSS 解决方案是理想的,我不担心旧浏览器。但我主要是在寻找任何方法来防止 javascript 在使用创建的主题设置高度的每个页面上运行(因为具有相同主题的页面可能具有不同数量的文本)。

已经有一些类似的问题,但他们接受的答案(例如,不要使用绝对定位)在我的情况下不起作用。除非有一种方法可以让多层可拖动/可调整大小的元素没有position:absolute。

最佳答案

我找到了纯 CSS 解决方案!总结:

  1. 将子元素设置为 position: relative 而不是 absolute。
  2. 将它们的 margin-right 设置为它们的负宽度,使它们的有效宽度为零,并使它们 float :保持在同一条线上。这使得它们的原点都为 0, 0。
  3. 然后我们可以设置它们的 left 和 margin-top 属性,将它们绝对定位在它们的父元素中。请注意,margin-top 是必需的,而不是 top,因为 top 不会下推父元素的底部。

JSFiddle here或以下代码:

<style>
div.layer { position: relative; float: left; }
div.layer1 { width: 400px; border: 1px solid black }
div.layer2 { margin-top: 20px; left: 100px; width: 100px; margin-right: -100px; border: 1px solid blue }
div.layer3 { margin-top: 30px; left: 170px; width: 100px; margin-right: -100px; border: 1px solid red }
div.layer4 { margin-top: 30px; left: 20px; width: 60px; margin-right: -60px; border: 1px solid green }
</style>
<div class="layer layer1" style="position: relative; display: block; width: 400px; border: 1px solid black;">
Container
<div class="layer layer2" contentEditable>Edit me</div>
<div class="layer layer3">
<div class="layer layer4" contentEditable>Edit me</div>
</div>
</div>

关于javascript - 扩展高度以包括绝对定位的 child ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18947691/

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