- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试创建一个翻转卡片功能,该功能在桌面 View 中悬停时起作用,而在移动 View 中单击时起作用。我能够使用 checkbox
和完全使用 CSS 来实现。
这是代码片段:
.flip-card {
width: 150px;
height: 180px;
margin: 1em;
perspective: 1500px;
}
.flip-card .flip-card-inner {
position: relative;
width: 100%;
height: 100%;
transform-style: preserve-3d;
transition: transform 0.8s cubic-bezier(0.75, 0, 0.85, 1);
}
.more {
display: none;
}
.more:checked ~ .flip-card-inner {
transform: rotateY(180deg);
}
.flip-card-front, .flip-card-back {
position: absolute;
width: 100%;
height: 100%;
backface-visibility: hidden;
transform-style: preserve-3d;
border-radius: 6px;
}
.inner {
height: 100%;
display: grid;
padding: 1.5em;
}
.flip-card-front {
background-color: #2980b9;
}
.flip-card-back {
transform: rotateY(180deg);
background-color: #fff;
border: 2px solid #f0f0f0;
}
@media screen and (min-width: 900px){
.flip-card-inner:hover {
transform: rotateY(180deg);
}
}
<div class="flip-card col-6">
<input type="checkbox" id="card1" class="more" aria-hidden="true">
<div class="flip-card-inner">
<label for="card1" aria-hidden="true">
<div class="flip-card-front" style="background-color: rgba(96,132,38,0.4); box-shadow: 3px 3px 4px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div class="font-weight-bold flip-card-front-book-title ml-2 mb-2">Outliers</div>
<div class="font-weight-bold flip-card-front-book-author ml-2" style="color: #A2671A;"> <span
class="text-muted">By</span> Malcolm Gladwell</div>
</div>
</label>
<label for="card1" aria-hidden="true">
<div class="flip-card-back" style="box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div>
<h5 >Added by</h5>
<strong >Jitesh</strong>
</div>
</div>
</label>
</div>
</div>
<div class="flip-card col-6 ">
<input type="checkbox" id="card2" class="more" aria-hidden="true">
<div class="flip-card-inner">
<label for="card2" aria-hidden="true">
<div class="flip-card-front" style="background-color: rgba(96,132,38,0.4); box-shadow: 3px 3px 4px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div class="font-weight-bold flip-card-front-book-title ml-2 mb-2">Shoe Dog</div>
<div class="font-weight-bold flip-card-front-book-author ml-2" style="color: #A2671A;"> <span
class="text-muted">By</span> Phil Knight</div>
</div>
</label>
<label for="card2" aria-hidden="true">
<div class="flip-card-back" style="box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div>
<h5 >Added by</h5>
<strong >Ishant</strong>
</div>
</div>
</label>
</div>
</div>
我正在显示多张卡片,并在移动 View 上使用它们的唯一 ID 进行翻转事件。现在,我需要添加一项功能,在单击任何其他卡片或单击其他任何地方后将卡片翻转回来。 (仅适用于移动 View )。目前,我必须手动单击每张卡片才能将其翻转回原始状态。
如果可能,我正在寻找基于 CSS 的解决方案。
附言如果无法使用纯 CSS,请提供一个使用 jquery 的可行解决方案,因为我是新手。
最佳答案
这里有一个纯 CSS 解决方案(有一个问题,我将在下面解释):
.flip-card {
width: 150px;
height: 180px;
margin: 1em;
perspective: 1500px;
display: inline-block;
}
#no-card-open:not(:checked) ~ .flip-card {
position: relative;
z-index: 2;
}
.flip-card .flip-card-inner {
position: relative;
width: 100%;
height: 100%;
transform-style: preserve-3d;
transition: transform 0.8s cubic-bezier(0.75, 0, 0.85, 1);
}
input[name="card-control"] {
display: none;
}
.more:checked + .flip-card-inner {
transform: rotateY(180deg);
}
.flip-card-front,
.flip-card-back {
position: absolute;
width: 100%;
height: 100%;
backface-visibility: hidden;
transform-style: preserve-3d;
border-radius: 6px;
}
.inner {
height: 100%;
display: grid;
padding: 1.5em;
}
.flip-card-front {
background-color: #2980b9;
}
.flip-card-back {
transform: rotateY(180deg);
background-color: #fff;
border: 2px solid #f0f0f0;
}
@media screen and (min-width: 900px) {
.flip-card-inner:hover {
transform: rotateY(180deg);
}
}
#screen {
display: fixed;
position: absolute;
top: 0;
left: 0;
width: 100vw;
height: 100vh;
z-index: 1;
}
#no-card-open:checked ~ #screen {
display: none;
}
<input type="radio" id="no-card-open" name="card-control" checked />
<label id="screen" for="no-card-open"></label>
<div class="flip-card col-6">
<input type="radio" id="card1-open" name="card-control" class="more" />
<div class="flip-card-inner">
<label for="card1-open" aria-hidden="true">
<div class="flip-card-front" style="background-color: rgba(96,132,38,0.4); box-shadow: 3px 3px 4px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div class="font-weight-bold flip-card-front-book-title ml-2 mb-2">Outliers</div>
<div class="font-weight-bold flip-card-front-book-author ml-2" style="color: #A2671A;"> <span
class="text-muted">By</span> Malcolm Gladwell</div>
</div>
</label>
<label for="no-card-open" aria-hidden="true">
<div class="flip-card-back" style="box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div>
<h5 >Added by</h5>
<strong >Jitesh</strong>
</div>
</div>
</label>
</div>
</div>
<div class="flip-card col-6 ">
<input type="radio" id="card2-open" name="card-control" class="more" />
<div class="flip-card-inner">
<label for="card2-open" aria-hidden="true">
<div class="flip-card-front" style="background-color: rgba(96,132,38,0.4); box-shadow: 3px 3px 4px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div class="font-weight-bold flip-card-front-book-title ml-2 mb-2">Shoe Dog</div>
<div class="font-weight-bold flip-card-front-book-author ml-2" style="color: #A2671A;"> <span
class="text-muted">By</span> Phil Knight</div>
</div>
</label>
<label for="no-card-open" aria-hidden="true">
<div class="flip-card-back" style="box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div>
<h5 >Added by</h5>
<strong >Ishant</strong>
</div>
</div>
</label>
</div>
</div>
<div class="flip-card col-6 ">
<input type="radio" id="card3-open" name="card-control" class="more" />
<div class="flip-card-inner">
<label for="card3-open" aria-hidden="true">
<div class="flip-card-front" style="background-color: rgba(96,132,38,0.4); box-shadow: 3px 3px 4px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div class="font-weight-bold flip-card-front-book-title ml-2 mb-2">Incognito</div>
<div class="font-weight-bold flip-card-front-book-author ml-2" style="color: #A2671A;"> <span
class="text-muted">By</span> David Eagleman</div>
</div>
</label>
<label for="no-card-open" aria-hidden="true">
<div class="flip-card-back" style="box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.4),
-3px -3px 4px rgba(255, 255, 255, 1);">
<div>
<h5 >Added by</h5>
<strong >Alvaro</strong>
</div>
</div>
</label>
</div>
</div>
此解决方案背后的想法:使用单选按钮代替复选框。
一组具有相同 name
的单选按钮一次最多只能有一个事件的单选按钮。而且您一次只想翻一本书/一张卡片。基于此,单选按钮似乎是比复选框更自然的解决方案。
因此,第 1 步:用单选按钮替换复选框。
现在我们找到了第一个问题:这样一次只能翻一张牌。但如果我点击翻转的卡片,它应该回到原来的位置……而现在,它没有。您可以通过添加一个新的单选按钮来解决这个问题,该按钮将指示没有卡片被翻转。
卡在正常状态下的标签会指向该卡的radio。翻转卡片的标签将指向“没有卡片被翻转”单选框,而不是指向卡片单选框。
第2步:添加一个radio来处理no-card-flipped状态。
还有最后一个问题。您需要单击卡片才能将其翻转回正常状态。当您在外部单击时,没有任何反应,即使您希望翻转的卡片进入正常状态,翻转的卡片也会保持翻转状态。
为避免这种情况,您可以创建一个视觉上隐藏的 label
,它会指向 no-card-flipped 状态。这个新标签将覆盖整个视口(viewport)并位于卡片之外的所有内容之上(在示例中,我为屏幕标签做了 z-index:1
和 z-index:2
用于卡片)。 屏幕标签仅在翻转卡片时可见。这样一来,无论您在屏幕上点击什么地方(卡片上除外),它都会将翻转的卡片返回到正常位置并隐藏屏幕。
第 3 步:添加一个“隐藏”屏幕,使所有卡片返回正常位置。
这就是问题所在:因为当卡片打开时屏幕覆盖了整个视口(viewport),您可能会看到一些奇怪的行为,例如,您单击链接或按钮,但第一次没有任何反应,你必须点击它两次。这是因为第一次点击是隐藏屏幕。
这就是带有陷阱的纯 CSS 解决方案 :)
注意:虽然可能有 CSS 选项,但我不建议使用它。上面的解决方案是特定于问题中给出的示例的,在更复杂的环境中可能会失败。
此外,整个系统的复杂性也大大增加。卡片越多,单选按钮就越多。使用 JavaScript 管理状态会更容易、更快速(而且它可能在可访问性方面也更好)。
关于html - 使用 CSS 单击其他卡片时返回 Flipkart,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65367059/
在 Android 的 API > 19 中是否有任何方法可以获取可移动 SD 卡的路径? 与外部 SD 卡一样,我们有 Environment.getExternalStorageDirectory
一些 Android 设备有 microSD(或其他存储卡)插槽,通常安装为 /storage/sdcard1 据我所知,自 Android 4.4 起 Google 限制了对此内存的访问,并在 An
我使用 Java Card 2.1.2 SDK 和 GPShell 作为与设备通信的方式在 Java Card 上构建一个项目。我从 GpShell 测试了 helloworld 示例,并成功发送了
我开发了一个应用程序,它有一个来电接收器,它适用于所有手机。一位用户有一部双 SIM 卡安卓手机。该应用程序适用于第一张 SIM 卡。但是当有人调用他的第二张 SIM 卡时,我们的应用程序不会被调用。
我有一个带预览的文件输入。 这是笔 Codepen 我想强制高度,我无法理解我该怎么做。我想将此组件的高度固定为 300px(示例),我还需要保持加载图像的正确纵横比,用灰色背景填充空白。现在我保持宽
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 6年前关闭。 Improve this qu
我正在使用此代码访问 SD card : import os from os.path import join from jnius import autoclass #from android.pe
我正在为数据记录设备编写固件。它以 20 Hz 的频率从传感器读取数据并将数据写入 SD 卡。但是,向SD卡写入数据的时间并不一致(大约200-300 ms)。因此,一种解决方案是以一致的速率将数据写
我正在使用以下代码将视频放到网站上,但是在垂直方向上,手机屏幕上只能看到视频的左半部分 我不是网络开发人员。有人可以告诉我确切的内容吗,如何使其正确放置在手机屏幕上? 是在youtube iframe
我正在使用 Vuetify 1.5 和 Vuetify 网格系统来设置我的布局。现在我有一个组件 HelloWorld我将其导入到我的 Parent 中成分。我已经在我的 HelloWorld 中设置
我使用 python 制作了一个简单的二十一点游戏。我制作了游戏的其余部分,但我正在努力放入 ASCII 卡,所以这只是代码的一小部分。我尝试将 * len(phand) 放在附加行的末尾。虽然这确实
我正在使用玩家卡设置 Twitter 卡。它可以在预览工具中运行,但文档说它需要在“twitter.com 现代桌面浏览器? native iOs 和 Android Twitter 应用程序?mob
任何旧的 GSM 兼容 SIM 卡(3G USIM 的奖励)。 我想我需要一些硬件?谁能为业余爱好者推荐一些便宜的东西,以及一些更专业的东西? 我认为会有一个带有硬件的 API 的完整文档,所以也许这
我使用 python 制作了一个简单的二十一点游戏。我制作了游戏的其余部分,但我正在努力放入 ASCII 卡,所以这只是代码的一小部分。我尝试将 * len(phand) 放在附加行的末尾。虽然这确实
我记得前一段时间读到有 cpu 卡供系统添加额外的处理能力来进行大规模并行化。任何人都有这方面的经验和任何资源来研究项目的硬件和软件方面吗?这项技术是否不如传统集群?它更注重功率吗? 最佳答案 有两个
我检查外部存储是否已安装并且可用于读/写,然后从中读取。我使用的是确切的官方 Android 示例代码 ( from here )。 它说外部存储未安装。 getExternalFilesDir(nu
在 Android 2.1 及更低版本中,Android 应用程序可以请求下载到 SD 卡上吗?另外我想知道应用程序是否可以请求一些包含视频的文件夹下载到 SD 卡上?以及如何做到这一点? 提前致谢。
我们编写了一个 Windows 设备驱动程序来访问我们的自定义 PCI 卡。驱动程序使用 CreateFile 获取卡的句柄。 我们最近在一次安装中遇到了问题,卡似乎停止工作了。我们尝试更换卡(更换似
有些新设备(例如 Samsung Galaxy)带有两个 SD 卡。我想知道是否有任何方法可以确定设备是否有两张 SD 卡或一张 SD 卡。谢谢 最佳答案 我认为唯一的方法是使用 检查可用根的列表 F
我正在尝试将文件读/写到 SD 卡。我已经尝试在我的真实手机和 Eclipse 中的模拟器上执行此操作。在这两种设备上,对/mnt/sdcard/或/sdcard 的权限仅为“d--------”,我
我是一名优秀的程序员,十分优秀!