- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为一个面板进行漫游,对于这个漫游指南,我需要在覆盖层上创建一个洞,这样底层元素只能从那个洞中点击。
我找到了一种在内部以某种方式实现它的方法,但我还需要防止针对该圆圈之外的底层元素。
注意:下面的示例是我正在制作的 React 组件的简化版本,我需要为焦点区域使用 border-radius 因为焦点区域将是一个动态区域并且可以从圆形变为方形(并且带过渡)根据指南下一步的目标元素。
任何基于 CSS 或 JavaScript 的解决方案都会很有帮助。 (但请不要使用 jQuery!)
提前谢谢你。
.content{
width: 100%;
height: 100%;
padding: 3rem;
box-sizing: border-box;
}
button{
padding: 1rem;
margin: 1rem;
}
.guide{
width: 9rem;
height: 9rem;
position: absolute;
z-index: 10;
top: 1.7rem;
left: 11.5rem;
border-radius: 9rem;
box-shadow: 0 0 0 1000rem rgba(0,0,0,0.5);
pointer-events: none;
}
<div class="content">
<button>test button</button>
<button>test button</button>
<button>test button</button>
<p>The user should only <br/>able to click on second button</p>
</div>
<div class="guide"></div>
最佳答案
使用 clip-path
的想法。你创建一个中间有一个圆圈的大元素,然后将它翻译到你想要的地方:
let precision = 64;
let radius = 1.7; /* control the radius here */
let c = [...Array(precision)].map((_, i) => {
let a = -i/(precision-1)*Math.PI*2;
let x = Math.cos(a)*radius + 50;
let y = Math.sin(a)*radius + 50;
return `${x}% ${y}%`
})
document.querySelector('.guide').style.clipPath =
`polygon(100% 50%, 100% 100%, 0 100%, 0 0, 100% 0, 100% 50%, ${c.join(',')})`;
/* credit to https://stackoverflow.com/a/63739677/8620333 for the code above */
.content{
padding: 3rem;
box-sizing: border-box;
}
button{
padding: 1rem;
margin: 1rem;
}
.guide{
width: 4000px;
height: 4000px;
position: fixed;
top:-2000px;
left:-2000px;
transform:translate(16rem,5.8rem); /* adjust this*/
background:rgba(0,0,0,0.5);
}
<div class="content">
<button>test button</button>
<button>test button</button>
<button>test button</button>
<p>The user should only <br/>able to click on second button</p>
</div>
<div class="guide"></div>
关于javascript - 指针事件 : none for inside of div and pointer-events: all for outside (reverse mode of normal div) - walkthrough tour container,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65737089/
我正在开发基于桌面 (Windows 7) 的应用程序,并使用 Qt Creator v 5.6.0 开发程序。我有一个非常奇怪的问题,即 我的程序在 DEBUG 模式下崩溃,但在 RELEASE 模
我爱org-tables ,我用它们来记录各种事情。我现在正在为 Nix 记录一些单行代码(在阅读了 Domen Kožar 的 excellent guide 后,在 this year's Eur
org-mode 是否有一个键绑定(bind)可以在编号/项目符号列表项之间移动,就像您可以对标题一样? 喜欢的功能: org-forward-heading-same-level 大纲下一个可见标题
我知道这有点小,但它一直困扰着我。我正在为一个项目使用 Org-mode,我倾向于经常导出为 PDF 或 HTML,这使我的目录中散落着 PDF、Tex 和 HTML 文件。有没有办法将 Org 模式
有什么方法可以让 org-mode 继续编号列表而不是重新启动? 这是情况。你列了一个类似的列表: Sometimes you can restart the display by doing som
如何在组织模式文件中生成所有标签的枚举列表(例如 :tag:)?假设我有一个以下形式的列表: * Head1 :foo:bar: ** Subhead1 :foo: * Head2
我正在使用 org-mode(Emacs:24.3.1,org-mode: 7.9.3f 8.0.6)作为不同代码片段的数据库语言(目前主要是 elisp 和 python)。这在使用 org-mod
相关问题:org-mode: fontify code blocks natively 截至 2012 年 11 月 1 日,我已经获得了最新的 org-mode 和 emacs 版本(组织存储在 o
有谁知道在使用 ido 模式时区分 dired 模式缓冲区名称与迷你缓冲区中其他类型缓冲区的好方法吗?例如...在 dired 模式缓冲区名称末尾显示正斜杠? 最佳答案 您可以简单地更改dired-m
在这个示例脚本中 import argparse parser = argparse.ArgumentParser() parser.add_argument('--modes', help="tes
我第一次学习“操作系统”。在我的书中,我发现了关于“用户模式”和“内核模式”的这句话: "Switch from user to kernel mode" instruction is execute
我刚刚下载了 Processing 2.0 并尝试从“模式管理器”安装 Android 模式。但是在安装时出现错误提示:“无法将模式“Android 模式”移动到速写本”。我怎样才能摆脱这个错误? 最
在 android L 中,我尝试将相机闪光灯模式设置为 TORCH,它工作正常,但我无法将其更改回闪光灯模式 AUTO 或闪光灯模式 打开。我只能返回闪存模式 OFF。我尝试了像 camera360
有 2 台机器,A 和 B。有 2 个分支,p16 和 c2。 A 有一个 ext3 文件系统,但在 B 上,存档位于带有 vfat 的 truecrypt 驱动器上,mount 显示 rw,uid=
我有 linum-mode在我的 Emacs 配置中全局启用。全局启用意味着它也适用于不受欢迎的速度条。 我为这个问题找到的唯一建议是在存档的 Emacs 帮助邮件列表中,它建议以下 speedbar
Google Cloud Firestore 将很快取代旧的 Google Cloud Datastore。然后可以选择在“ native 模式”或“数据存储模式”下使用 Cloud Firestor
org-mode的版本我的版本 Emacs 附带的(24.5.2) 是 8.2.10 .我已安装版本 8.3.1从 ELPA 并将其添加到我的 init 文件中: (add-to-list 'load
The org-mode manual指出 org-mode 将“”“...在 shell 链接”“”中执行命令,但它不显示此类链接的语法。 我希望能有一个简单完整的示例来说明这种 shell 链接是
我正在尝试在 emacs 24 中使用 dart 模式和 d 模式。如果我单独使用任何一种模式,一切都很好。如果我分别对每种类型的文件使用这两种模式,我在尝试缩进 D 代码时会出错。 以下是在初始化时
我的应用程序中有 CupertinoDatePicker 以使用以下代码选择日期和时间: formatColumn( widget: Consumer( builder: (_, mcProvide
我是一名优秀的程序员,十分优秀!