html - 带有 x 滚动的 CSS 绝对位置

标签 html css

这是例子:

https://jsfiddle.net/yaxfnmtn/

我有一个 div,我想在上面画一些条纹。它工作正常,除非我在 div 上滚动 x,在那里我再也看不到它们了。这是 HTML 代码:

<div class="outer">
  <div class="bg"></div>
  <div class="inner"></div>
</div>

还有 CSS:

.outer {
  width: 300px;
  height: 200px;
  overflow-x: scroll;
  overflow-y: hidden;
  border: 1px solid black;
  position: relative;
}

.inner {
  width: 1000px;
  height: 200px;
}

.bg {
  background-image: linear-gradient(#eee 0.1em, transparent 0.1em);
  background-size: 100% 0.7em;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
}

这是我要实现的目标的一个非常简化的版本。将其设置为 position: fixed 似乎不是一个选项?

最佳答案

这是不可能的。

当您为子项分配 100% 宽度时,这意味着父项宽度不是文档。

除了让父溢出的是<div class="inner">宽度为 1000xp,其中条纹分配给 <div class="bg">其宽度为 100%,等于父级的宽度。

因此,改为将 strippes 应用于 .outer,当子项溢出时,它将保持背景。

.outer {
  width: 300px;
  height: 200px;
  overflow-x: scroll;
  overflow-y: hidden;
  border: 1px solid black;
  position: relative;
  background-image: linear-gradient(#eee 0.1em, transparent 0.1em);
  background-size: 100% 0.7em;
}

.inner {
  width: 1000px;
  height: 200px;
}

.bg {

  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
}
<div class="outer">
  <div class="bg"></div>
  <div class="inner"></div>
</div>

关于html - 带有 x 滚动的 CSS 绝对位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50178239/

相关文章:

jquery - 视差仅适用于页面刷新,不适用于重定向

jquery - 数据表插件 : if not sortable remove text-decoration from column header

html - Bootstrap 两个 col-sm 但 xs 为两行

html - 为打印和屏幕应用样式表

javascript - 带有 jquery Math 和 CSS 百分比值的视差

html - 在其他 CSS 选择器上使用元素 ID/类名

javascript - Div 不会继续使用媒体查询

javascript - 如何使 JAVASCRIPT 变量等于 HTML 属性?

html - 创建一个以图像为列表项的无序列表

html - 任意大小的 img 的静态最大/最小宽度