如何在input元素下显示搜索结果列表?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在input元素下显示搜索结果列表?相关的知识,希望对你有一定的参考价值。

我想在输入下的list-group(Bootstrap)中显示搜索结果,我在哪里,hovering my mouse

如果我在搜索div之后创建一个列表,it starts位于屏幕顶部。

如何在搜索下方定位列表?

body,
html {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
}

.content {
  font-family: 'Cutive Mono', monospace;
}

.search {
  top: 37%;
  left: 50%;
  transform: translate(-50%, -50%);
  position: absolute;
  font-weight: 100;
}
<div class="content">

  <div class="search">
    INPUT
  </div>

  <div class="list-group">
    LIST ITEMS
  </div>

</div>
答案

看来你正在使用position:absolute来垂直和水平居中输入。但是,绝对定位会从文档流中删除元素,因此相对于该元素定位另一个元素可能会产生看似意外的结果。

绝对 该元素从正常文档流中删除;没有为页面布局中的元素创建空间。 - position @ MDN


一个替代的想法是使用flexible box layout.content元素成为“flex容器”,它的两个子元素在其父级中水平和垂直居中。

下面,我使用了Bootstrap flex classes

body,
html {
  margin: 0;
  padding: 0;
  width: 100%;
  height: 100%;
}

.content {
  height: 100%;
  font-family: 'Cutive Mono', monospace;
}

.search {
  margin: 0 0 1em;
}
<link href="//maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" rel="stylesheet" />

<div class="content d-flex flex-column justify-content-center align-items-center">

  <div class="search">
    <input type="text" placeholder="search">
  </div>

  <ul class="list-group">
    <li class="list-group-item">Test</li>
    <li class="list-group-item">Another Test</li>
    <li class="list-group-item">Sample</li>
    <li class="list-group-item">Another Sample</li>
    <li class="list-group-item">Last one</li>
  </ul>

</div>

以上是关于如何在input元素下显示搜索结果列表?的主要内容,如果未能解决你的问题,请参考以下文章

如何找到列表中两个元素的最大乘积?

不要在片段中显示列表视图项

使用 .next() 遍历列表项的问题

如何对数组列表的元素求和?

Android - 如何显示包含从片段中获取的字符串的快餐栏

从另一个片段返回时如何在视图页面中显示片段?