- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个元素,其宽度是固定的 px
值或百分比。我希望它的边界框的右侧位于屏幕(或视口(viewport))的 x 坐标 −1 处,因此它的右侧接触屏幕的左侧 — 元素将变得不可见这个。
CSS right
或 left
属性是否有可用于百分比和固定 px
宽度的值,或者是否存在有其他方法可以实现吗?
最佳答案
这套 CSS 规则适用于此:
/* These rules position the element just beyond the left edge of the viewport. */
.positioned {
position: absolute;
left: 0;
transform: translateX(-100%);
}
/* You can open your developer tools (Right Click → Inspect Element) and change the `-100%` from above to see this box. */
.positioned {
width: 100px;
height: 100px;
background: rebeccapurple;
padding: 4px;
color: white;
}
<div class="positioned">
I’m on the left.
</div>
position: absolute
和 left: 0
将元素放在左边缘,但在视口(viewport)内。那么 transform: translateX(-100%)
是将元素向左移动的规则,正好是其宽度。
这是有效的,因为如果 translate
的参数, translateX
, 或 translateY
是百分比,那么这些百分比与元素的宽度和高度有关。对于其他属性,例如 left
或 right
,它们与父级的宽度和高度有关。因此,left
和 right
不能在所有情况下用于此 — 相对或固定宽度 —,这就是为什么您对原始问题的回答是:不,这两个属性没有实现此目的的值(value)。可能有某种形式的诡计来实现这一点,但 CSS3 的 transform
功能(或个别 — 尽管不太兼容 — 属性)使这变得容易。
如果您运行该代码段,您应该什么都看不到。如果您使用 browser console (dev tools) (点击 F12
)并检查代码片段的结果并找到 <div class="positioned">
,你会看到这个:
关于html - 如何将元素定位在视口(viewport)左边缘之外?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31420316/
我正在尝试获得一个按钮,按下该按钮时会改变颜色。当再次按下时,它应该变回原来的颜色。我究竟做错了什么? 我的模板中的按钮: export default { data: {
我是一名优秀的程序员,十分优秀!