本文将介绍一个非常有意思的功能,使用纯 css 利用 resize 实现强大的图片切换预览功能。类似于这样:
首先,要实现这样一个效果如果不要求可以拖拽,其实有非常多的办法。
将两张图片叠加在一起改变上层图片的宽度,或者使用 mask, 改变 mask 的透明度区间变化两种方式都简单示意一下。
假设我们的结构如下,分别使用 background
展示两张图片:
<div class="g-outer"> <div class="g-inner"></div></div>
方法一,改变上层图片的宽度的方式:
.g-outer { width: 650px; height: 340px; background-image: url(image1.png); overflow: hidden;}.g-inner { height: 340px; background: url(image2.png); animation: widthchange 3s infinite alt竞选优势ernate linear;}@keyframes widthchange { 0% { width: 650px; } 100% { width: 0px; }}
效果如下:
当然,使用 mask
遮罩的方式也非常轻松的可以实现类似的效果:
.g-outer { background-image: url(https://images.cnblogs.com/cnblogs_com/coco1s/881614/o_21081614180122.png);}.g-inner { background: url(https://images.cnblogs.com/cnblogs_com/coco1s/881614/o_21081614175811.png); mask: linear-gradient(90deg, #fff 0%, #fff 50%, transparent 50%, transparent 100%); mask-size: 200% 100%; animation: maskchange 2s infinite alternate linear;}@keyframes maskchange { 0% { mask-position: -100% 0; } 100% { mask-position: 0 0; }}
也可以得到同样的效果:
上述 demo 的完整代码:codepen demo — switch picture
对强大的 mask 属性还不是太了解的,可以猛戳:奇妙的 css mask
下一步则是最核心,最关键的一步,巧妙的使用 css resize
属性,实现拖拽控制元素的宽度。
什么是 resize
?
resize
:该属性允许你控制一个元素的大小
语法如下:
{/* keyword values */ resize: none; resize: both; resize: horizontal; resize: vertical; resize: block; resize: inline;}
看一个最简单的 demo:
<p>lorem ipsum dolor sit amet, conctetur adipisicing elit. a气体体积分数 aut qui labore rerum placeat similique hic conquatur tempore doloribus aliquid alias, nobis voluptates. perferendis, vollog函数图像uptate placeat es soluta deleniti id!</p>
p { width: 200px; height: 200px; resize: horizontal; overflow: scroll;}
这里,我们设置了一个长宽为 200px
的 <p>
为横向可拖拽改变宽度。效果如下:
简单总结一些小技巧:
resize
的生效,需要配合 overflow: scroll
,当然,准确的说法是,overflow
不是 visible
,或者可以直接作用于替换元素譬如图像、<video>
及 <iframe>
、<textarea>
等我们可以通过 resize
的 horizontal
、vertical
、both
来设置横向拖动、纵向拖动、横向纵向皆可拖动。可以配合容器的 max-width
、min-width
、max-height
、min-height
限制可拖拽改变的一个范围ok,接下来,我们将 resize 运用于图片拖拽切换。
首先,还是上述的代码,我们将 resize 作用于子元素试试:
<div class="g-outer"> <div class="g-inner width-change"></div></div>
.g-outer { width: 650px; heigh高考前祝福语 八个字t: 340px; background-image: url(image1.png); overflow: hidden;}.g-inner { height: 340px; background: url(image2.png); resize: horizontal; overflow: scroll; max-width: 640px; min-width: 10px;}
可以看到,g-inner
设置了 resize: horizontal
,将允许被横向拖动,实际的效果我成功了作文400字如下:
嗯,非常接近了,因为需要配合 overflow: scroll
,所以出现了恼人的滚动条,非常的不美观,我们得想办法干掉滚动条。
隐藏滚动条的方式有很多,这里我们介绍其中一种巧妙的方式,我们对我们的结构进行一下改造,再叠加多一层 div:
<div class="g-outer"> <div class="g-inner"> <div class="g-resize"></div> </div></div>
我们将控制拖拽这个功能交给 g-resize
,它负责改变元素的宽度,而 g-inner
改为绝对定位,当 g-resize
的宽度增大时,其父元素 g-inner
也会随之增大,最后设置 g-resize
的 opacity
为 0 即可隐藏滚动条。
核心代码如下:
.g-outer { position: relative; width: 650px; height: 340px; background-image: url(image1.png); overflow: hidden;}.g-inner { position: absolute; top: 0; left: 0; min-width: 0; max-width: 650px; height: 340px; background-image: url(image2.png);}.g-resize { position: relative; resize: horizontal; overflow: scroll; width: 0; height: 340px; max-width: 650px; min-width: 15px; animation: opacitychange 3s infinite alternate linear;}@keyframes opacitychange { 0% { opacity: 0; } 100% { opacity: 1; }}
这里,为了方便示意,我将 opacity
设置了一个渐隐渐现的动画效果,方便示意:
最后一步,由于完全隐藏了滚动条,用户也就不知道可以拖拽了,所以我们还需要绘制一个更为好看的拖拽条,这里延续上述的布局,给 .g-inner
再添加一个伪元素,绝对定位在元素最后即可:
.g-inner:before { content: "↔"; position: absolute; background: rgba(0, 0, 0, 0.5); top: 0; right: 0; height: 100%; line-height: 340px;}
最终完美达成效果:
完整详细的代码,你可以在我的 css 灵感上看到:
css 灵感 — 利用 resize 实现图片切换预览功能
通过本文,你可以学会:
利用 resize 来实现容器大小的控制通过一些巧妙的方式来隐藏不太美观的滚动条以及配合上述的一些技巧,使用纯 css 实现图片拖拽切换预览功能最后
好了,本文到此结束,希望对你有帮助
更多精彩 css 效果可以关注我的 css 灵感
更多精彩 css 技术文章汇总在我的 github — icss ,持续更新,欢迎点个 star 订阅收藏。
到此这篇关于css 使用 resize 实现图片拖拽切换预览功能(强大功能)的文章就介绍到这了,更多相关css resize图片拖拽切换预览内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章,希望大家以后多多支持www.887551.com!
本文发布于:2023-04-07 20:06:01,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/bf4d342efbfff859bf23c343465c051e.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:CSS 使用 resize 实现图片拖拽切换预览功能(强大功能).doc
本文 PDF 下载地址:CSS 使用 resize 实现图片拖拽切换预览功能(强大功能).pdf
留言与评论(共有 0 条评论) |