微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何固定一个元素在 flexbox 中的位置?

如何解决如何固定一个元素在 flexbox 中的位置?

我有 2 个盒子:面板和侧边栏,在 flexBox 中,带有 flex-direction: rowjustify-content: space-between 我能够将它们并排水平对齐,中间有间隙。

现在我想修复右侧的侧边栏位置,即向下滚动时,侧边栏应始终保持在屏幕顶部,无论面板的位置如何。我怎样才能用 CSS 做到这一点?

此处的工作示例:https://codesandbox.io/s/gallant-saha-zgmnw

代码在这里

App.js:

import React from "react";
import "./App.scss";
import Panel from "./Panel";
import Sidebar from "./Sidebar";

export default function App() {
  return (
    <div className="App">
      <Panel />
      <Sidebar />
    </div>
  );
}

App.scss:

.App {
  width: 1100px;
  font-family: sans-serif;
  text-align: center;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
}

Panel.js:

import React from "react";
import "./Panel.scss";

const Panel = () => {
  return (
    <>
      <div className="panel">The main panel</div>
    </>
  );
};

export default Panel;

Sidebar.js:

import React from "react";
import "./Sidebar.scss";

const Sidebar = () => {
  return (
    <>
      <div className="sidebar">The sidebar</div>
    </>
  );
};

export default Sidebar;

解决方法

我修改了你的侧边栏 css。 我使用了位置固定,因为这将使侧边栏固定在视口中,以便您滚动时它会保持静态。

.sidebar {
  position: fixed;            /* add this */
  width: 200px;
  height: 200px;
  text-align: center;
  border: 1px black solid;
  left: 906px                /* add this */
}

这会产生预期的效果。测试和工作。抱歉,我已经更新了我的答案。

,

将此 css 添加到 .sidebar

position:fixed;
right: 10px;

此外,您还可以添加:

top: -- px

如果你有导航栏。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?