JS利用|JS利用 clip-path 实现动态区域裁剪功能
背景
今天逛 CodePen,看到了这样一个非常有意思的效果:
文章图片
CodePen Demo -- Material Design Menu By Bennett Feely
这个效果还是有一些值得探讨学习的点,下面我们一起来看看。
如何实现这样一个类似的效果?
首先,想一想,如果让你去实现上面的效果,你会怎么做呢?
这里我简单罗列一些可能的办法:
- 阴影 box-shadow
- 渐变 radial-gradient
- 缩放 transform: scale()
使用 box-shadow 实现 如果使用
box-shadow
,代码大致如下:.g-container {position: relative; width: 400px; height: 300px; overflow: hidden; }.g-item {position: absolute; width: 48px; height: 48px; border-radius: 50%; background: #fff; top: 20px; left: 20px; box-shadow: 0 0 0 0 #fff; transition: box-shadow .3s linear; &:hover {box-shadow: 0 0 0 420px #fff; }}
核心就在于:
- 外层一个设置了
overflow: hideen
的遮罩 - 内层元素 hover 的时候,实现一个
box-shadow: 0 0 0 0 #fff
到box-shadow: 0 0 0 420px #fff
的变化
文章图片
整体的动画是模拟出来了,但是它最致命的问题有两个:
- 当我们的鼠标离开圆形的时候,整个动画就开始反向进行了,白色区域开始消失,如果我们要进行按钮操作,是无法完成的
- 隐藏在动画展开后的矩形内的元素,不容易放置
box-shadow
看着虽好,但是只能放弃。上述 Demo 的代码 -- CodePen Demo -- box-shadow zoom in animation使用渐变 radial-gradient 实现 下面我们使用径向渐变
radial-gradient
加上 CSS @property,也可以还原上述效果:@property --size {syntax: ''; inherits: false; initial-value: 24px; }.g-container {position: relative; width: 400px; height: 300px; overflow: hidden; background: radial-gradient(circle at 44px 44px, #fff 0, #fff var(--size), transparent var(--size), transparent 0); transition: --size .3s linear; &:hover {--size: 450px; }}
我们通过控制径向渐变的动画效果,在 hover 的时候,让原本只是一个小圆背景,变成一个大圆背景,效果如下:
文章图片
emmm,效果确实是还原了,问题也很致命:
- 由于是背景的变化,所以鼠标不需要 hover 到小圆上,只需要进入 div 的范围,动画就会开始,这显然是不对的
- 和第一种
box-shadow
的方法类似,隐藏在白色之下的导航元素的 DOM 不好放置
emmm,还有一种方法,通过缩放
transform: scale()
,也会存一定问题,这里不继续展开。所以到这里,想实现上述的效果,核心在于:
- 鼠标要 hover 到圆上,才能开始动画,并且,鼠标可以在展开后的范围内自由移动,且不会收回动画效果
- 动画展开后,里面的 DOM 的放置,不能太麻烦,能不借助 Javascript 去控制里面内容的显示隐藏最好
在我的这篇文章中 -- 如何不使用 overflow: hidden 实现 overflow: hidden?,介绍了 CSS 中几种裁剪元素的方式,而其中,最适合利用在这个效果的,就是 -- clip-path。
利用
clip-path
,可以非常好的实现,动态裁剪的功能,并且,代码也非常简单:.g-container {position: relative; width: 400px; height: 300px; overflow: hidden; transition: clip-path .3s linear; clip-path: circle(20px at 44px 44px); background: #fff; &:hover {clip-path: circle(460px at 44px 44px); }}
我们只需要利用
clip-path
,在最开始的时候,将一个矩形 div,利用 clip-path: circle(20px at 44px 44px)
裁剪成一个圆,当 hover 的时候,扩大裁剪圆的半径到整个矩形范围即可。效果如下:
文章图片
这样,我们就能完美的实现题图的效果,并且,内置的 DOM 元素,直接写进这个 div 内部即可。
- 11111
- 22222
- 33333
- 44444
效果如下:
文章图片
CodePen Demo -- clip-path zoom in animation
很有意思的一个技巧,利用 clip-path 实现动态区域裁剪,希望大家能够掌握。
【JS利用|JS利用 clip-path 实现动态区域裁剪功能】到此这篇关于JS利用 clip-path 实现动态区域裁剪功能的文章就介绍到这了,更多相关clip-path区域裁剪内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 利用Python绘制酷炫的3D地图
- C#|C# 中使用Stopwatch计时器实现暂停计时继续计时功能
- 利用python设计图像加密技术(Arnold算法)
- #|基于蒙特卡洛法的规模化电动汽车充电负荷预测(Python&Matlab实现)
- #|一场樱花雨(Python实现)
- 机器学习|AlexNet网络结构详解及TensorFlow代码实现
- 【JS30-Wes Bos】异步操作实现的小字典
- 使用git命令上传代码
- CoLAKE:|CoLAKE: 如何实现非结构性语言和结构性知识表征的同步训练
- 利用Matlab绘制有趣图像的示例代码