- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个屏幕,其中有 3 个水平对齐的主要区域:
侧边栏 (1) 可以折叠/隐藏(向左)。隐藏时,释放的空间应分配给可视化 (3),而菜单宽度 (2) 保持不变。
ATM 我正在对齐这样的内容:
display: flex
width: 260px;
width: 293px;
flex: 1;
width: 0
对于侧边栏。
width
通过更改和动画/转换
left
来更改或着手处理它属性或使用边距等,但我能想到的所有这些解决方案都会触发浏览器布局步骤(更改
width
、
left
、
margin
、...)动画性能解释
here .
translate
等等。
width
属性或不将释放的空间重新分配给剩余的可见内容(例如,侧边栏仅显示在主要内容的“上方”等),因此到目前为止我发现的所有示例都没有真正满足我描述的目标......
最佳答案
请检查以下HTML
, JS
, CSS
片段。您可以更改元素的实际宽度以与您需要的完全匹配。
操纵width
侧边栏不是问题。性能,如 link 中所述你提供的。在这篇文章的最后一行是这样写的:
Performance matters to users. Web developers need to build apps thatreact quickly and render smoothly. Google performance guru Paul Lewisis here to help you destroy jank and create web apps that maintain 60frames per second performance. You'll leave this course with the toolsyou need to profile apps and identify the causes of jank. You'llexplore the browser's rendering pipeline and uncover patterns thatmake it easy to build performant apps.
Javascript
重新创建以下示例的逻辑
requestAnimationFrame
如图
here .
const side = document.querySelector('.side');
const sideToggle = document.querySelector('.sideToggle');
const main = document.querySelector('.main');
sideToggle.addEventListener('click', () => {
if (!sideToggle.classList.contains('active')) {
sideToggle.classList.add('active');
} else {
sideToggle.classList.remove('active');
}
if (!main.classList.contains('full')) {
main.classList.add('full');
} else {
main.classList.remove('full');
}
if (!side.classList.contains('hidden')) {
side.classList.add('hidden');
} else {
side.classList.remove('hidden');
}
});
.container {
display: inline-flex;
flex-direction: row;
align-items: stretch;
align-content: space-evenly;
justify-content: space-evenly;
width: 100%;
}
.side {
display: flex;
flex-direction: column;
align-items: stretch;
align-content: space-evenly;
justify-content: space-evenly;
background: #000;
padding: 0;
width: 20%;
height: 100vh;
transition: width 1s linear;
}
.side a {
color: #fff;
text-decoration: none;
line-height: 1;
height: 1.5rem;
padding: 1rem;
}
.side a:hover {
color: #000;
background: #fff;
}
.side.hidden {
width: 0;
transition: width 1s linear;
}
.sideToggle {
background: #000;
color: #fff;
width: 2rem;
height: 2rem;
position: fixed;
right: .75rem;
bottom: .75rem;
border-radius: 50%;
text-align: center;
cursor: pointer;
z-index: 1001;
}
.sideToggle:after {
content: "\2630";
font-size: 1.25rem;
vertical-align: top;
}
.sideToggle.active:after {
content: "\00D7";
vertical-align: top;
font-size: 1.75rem;
}
.main {
background: red;
width: 80%;
height: 100vh;
transition: width 1s linear;
display: inline-flex;
flex-direction: row;
align-items: stretch;
align-content: space-evenly;
justify-content: space-evenly;
width: 100%;
color: #fff;
}
.main.full {
width: 100%;
transition: width 1s linear;
}
.left {
width: 15rem;
padding: 1rem;
}
.right {
width: calc(100% - 15rem);
background: indigo;
padding: 1rem;
}
<div class="container">
<div class="side">
<a href="#">Home</a>
<a href="#">Page 1</a>
<a href="#">Page 2</a>
<a href="#">Page 3</a>
</div>
<span class="sideToggle active"></span>
<div class="main">
<div class="left">
this width is ment to be static
</div>
<div class="right">
this width is ment to be dynamic
</div>
</div>
</div>
translateX
并且不改变
width
的侧边栏。
const side = document.querySelector('.side');
const sideToggle = document.querySelector('.sideToggle');
const main = document.querySelector('.main');
sideToggle.addEventListener('click', () => {
if (!sideToggle.classList.contains('active')) {
sideToggle.classList.add('active');
} else {
sideToggle.classList.remove('active');
}
if (!main.classList.contains('full')) {
main.classList.add('full');
} else {
main.classList.remove('full');
}
if (!side.classList.contains('hidden')) {
side.classList.add('hidden');
} else {
side.classList.remove('hidden');
}
});
.container {
display: inline-flex;
flex-direction: row;
align-items: stretch;
align-content: space-evenly;
justify-content: space-evenly;
width: 100%;
}
.side {
display: flex;
flex-direction: column;
align-items: stretch;
align-content: space-evenly;
justify-content: space-evenly;
background: #000;
padding: 0;
width: 7rem;
transform: translateX(0);
height: 100vh;
transition: transform 1s linear, z-index 1s linear;
z-index: 9999;
position: fixed;
left: 0;
top: 0;
will-change: transform, z-index;
}
.side a {
color: #fff;
text-decoration: none;
line-height: 1;
height: 1.5rem;
padding: 1rem;
}
.side a:hover {
color: #000;
background: #fff;
}
.side.hidden {
transform: translateX(-100%);
transition: transform 1s linear, z-index 1s linear;
z-index: -1;
}
.sideToggle {
background: #000;
color: #fff;
width: 2rem;
height: 2rem;
position: fixed;
right: .75rem;
bottom: .75rem;
border-radius: 50%;
text-align: center;
cursor: pointer;
z-index: 1001;
}
.sideToggle:after {
content: "\2630";
font-size: 1.25rem;
vertical-align: top;
}
.sideToggle.active:after {
content: "\00D7";
vertical-align: top;
font-size: 1.75rem;
}
.main {
background: red;
width: calc(100% - 7rem);
height: 100vh;
transition: transform 1s linear, width 1s linear;
display: inline-flex;
flex-direction: row;
align-items: stretch;
align-content: space-evenly;
justify-content: space-evenly;
color: #fff;
left: 0;
top: 0;
transform: translateX(7rem);
position: absolute;
will-change: transform, width;
}
.main.full {
transform: translateX(0);
width: 100%;
transition: transform 1s linear, width 1s linear;
}
.main .left,
.main.full .left {
flex-grow: 1;
flex-shrink: 1;
width: 15rem;
padding: 1rem;
}
.right {
flex-grow: 2;
flex-shrink: 2;
width: calc(100% - 15rem);
background: indigo;
padding: 1rem;
}
<div class="container">
<div class="side">
<a href="#">Home</a>
<a href="#">Page 1</a>
<a href="#">Page 2</a>
<a href="#">Page 3</a>
</div>
<span class="sideToggle active"></span>
<div class="main">
<div class="left">
this width is ment to be static
</div>
<div class="right">
this width is ment to be dynamic
</div>
</div>
</div>
关于html - 如何平滑地动画隐藏影响其他区域大小的侧边栏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55868982/
这是一个非常笼统的问题,我希望我能答对。 我正在研究 SSL/TLS 重新协商并已阅读了一些内容。这是我从阅读中了解到的内容: 从 SSL/TLS 重新协商的角度来看,客户端分为两个主要组,打补丁的和
第一个屏幕是艺术的细节。当我向上滚动时,标题将是 alpha。我点击另一个“艺术”到另一个细节 UI,然后按回到 Previous UI。之前的UI标题是黑色的,怎么变透明了。 布局:
想知道 mv 对基表的影响。它会减慢基表的速度吗?它什么时候开始写入 mv,就像同时写入基表和 mv 一样? 如果我有 local_quorum 的 CL 且 RF=3,客户端是否必须等到写入 mv
似乎在任何地方都找不到太多关于此问题的帮助,所以我想我会在这里尝试。 我正在尝试制作一个简单的 for 循环,当我将鼠标悬停在 html 卡上时,它会隐藏卡中的一些文本。该卡有一个简单的名字和姓氏,我
我有一个程序每帧运行 tick() 方法。我希望一个对象根据设定的重力常数下落,因此我创建了一个 Ball 对象,该对象会将其位置更新为前一帧的位置减去 y 速度。每个刻度 y 速度都会减少重力常数。
我的 KeyHandler 在这里: private void KeyHandler(java.awt.event.KeyEvent evt) {
我有一个方法,其中使用了很多其他类,包括链接列表、队列和堆栈。在我的方法中,我有一个 for 循环,我想在其中弹出堆栈(方便地命名为 s)并将队列(方便地命名为 q)出队到 s1 和 q1。由于某种原
我有一个 JTree 节点数组和另一个自定义对象的相应数组。 我想要什么:当选择 JTree 的节点时,相应对象(其数组中索引与节点数组中所选节点索引相同的对象)的字段填充 JLabels。 我被困在
我知道浏览器完成了处理客户端脚本(Javascript、JQuery 等)的所有工作,但想知道在性能方面是否还有其他重要因素(网络速度、客户端计算机速度、服务器环境) 如果它完全依赖于浏览器(类型和版
我有一个 Android 服务在后台运行,它将使用以下代码: while(true) { ServerSocket server = new ServerSocket(1234); Socke
对JQM有以下疑惑: 1.如果我们在单独的 html 文件中使用重复的 id,对 jquery mobile 有什么影响。 假设我们在单独的 html 文件中有重复的 id,但如果我们不使用该 id
我正在尝试更新两个(inventory、sold)MySQL 表的表库存。 假设我们正在处理的 sku 是 BT888-16 UPDATE inventory JOIN sold ON invento
我使用这种方法来更改我的表格单元格值, 它在 jtable 上改变但在文本文件上没有改变! public class user_AllBooks extends AbstractTableModel
我想在向表中插入数据时创建一个 MYSQL 存储过程,数据也会被插入到其他服务器表中。 我知道这在 ORACLE 数据库中是可能的,但我不知道它是否适用于 MYSQL。 有什么办法吗? 最佳答案 是的
我在 css 方面非常糟糕,只能靠 SO 答案来解决 - 但是我找不到针对这个特定问题的任何解释。 我有一个表单,其中包含一个 textarea 和一个 button(input/submit),仅此
我在一个元素上有动画,但它的移动也会影响 sibling 。如何在不影响兄弟元素的情况下仅在元素上使用动画? 问题示例: function animateSearch() { $('.glyph
我试图在我的 ViewController 中的 UIView 的所有四个边上建立一个阴影 — 在我通过 Xcode 向 UIView 添加约束之前,它工作得很好。我怎样才能使 UIView 的阴影显
自从我使用 JavaScript 以来已经有一段时间了 - 在获得证书之后我开始学习 Perl 并从那时起就一直使用它。我只是想重新开始使用 JS,我已经写了这个,我想说的是,这是一个简单的小脚本,可
我正在处理一个 HTML 元素,我添加了一个复选框,选中后会高亮显示所有文本输入字段。唯一的问题是一些输入字段在表格内,出于某种原因我无法用我的代码影响它们。任何帮助将不胜感激。 相关代码: HTML
我为 String 类创建了一个小扩展,以便方便地从中删除字符。这是它的样子: mutating func drop(characters chars: [String]) { for c i
我是一名优秀的程序员,十分优秀!