首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >当其他元素的大小发生变化时,绝对定位的元素会移动

当其他元素的大小发生变化时,绝对定位的元素会移动
EN

Stack Overflow用户
提问于 2018-02-25 09:33:10
回答 1查看 225关注 0票数 0

我创建了这个jsfiddle来演示我的问题:https://jsfiddle.net/k5mzg46k/17/

HTML:

代码语言:javascript
运行
复制
<div class="container">
    <input type="button" id="btn1">
    <p id="text">
        LOL LOL
    </p>
    <input type="button" class="btn2">
</div>

JS:

代码语言:javascript
运行
复制
document.getElementById("btn1").onclick =

function run() {
    var element = document.getElementById("text");
  element.innerHTML = "";
}

CSS:

代码语言:javascript
运行
复制
#text {
        margin: 0 auto;
    width: -webkit-min-content;
    width: -moz-min-content;
    width: min-content;
    font-size: 14px;
}

#btn1{
  height: 47px;
  width: 47px;
}

.btn2 {
    margin-top: 5px;
    height: 30px;
    position: absolute;
    left: 0;
    right: 0;
}

.container {
    display: inline-block;
    position: relative;
    border: 1px solid black;
}

所以我有一个div容器,顶部有一个按钮,下面有一些文本,底部有一个按钮。我需要底部的按钮无论如何都要留在那里,所以我试着使用绝对定位。但是,当按下第一个按钮时,中间的文本将被删除,这会使底部按钮向上移动。

我怎么才能让它工作呢?谢谢。

EN

Stack Overflow用户

回答已采纳

发布于 2018-02-25 09:49:48

有几种方法可以做到这一点。您可以将JavaScript更改为仅隐藏元素:

代码语言:javascript
运行
复制
document.getElementById("btn1").onclick =

function run() {
  var element = document.getElementById("text");
  element.style.visibility = 'hidden';
}

或者,如果您必须删除元素,您可以将按钮放在div之外,display: absolute将起作用(也可以更改按钮的左侧和右侧):

代码语言:javascript
运行
复制
<div class="container">
<input type="button" id="btn1">
<p id="text">
LOL LOL
</p>
</div>
<input type="button" class="btn2">

票数 0
EN
查看全部 1 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48969388

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档