好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

html5教程-借助CSS Shapes实现元素滚动自动环绕iPhone X的刘海

小宝典致力于为广大程序猿(媛)提供高品质的代码服务,请大家多多光顾小站,小宝典在此谢过。

&nbs p;

一、iPhone X的刘海发型和衍生的交互

iPhone X造型上有个显著的特质,就是有个明显的刘海。

然后,也出现了一些酷酷的交互。

例如下面这个交互:

交互视频效果戳这里体验:http://t.cn/Rp01GKc

就是页面滚动的时候,列表会自动绕着iPhone X的刘海排列。

看上面微博截图的反应,好像觉得这个效果实现很难,实际上, CSS 3里面针对这种特定形状环绕的效果已经支持很久了,CSS3 Shape s和CSS3 Regions都是可以实现的,本文就将展示如何使用CSS3 Sha PE s实现元素内容在滚动的时候自动环绕iPhone X的齐刘海的效果。

二、CSS3 Shapes实现元素滚动自动环绕iPhone X头部刘海效果

眼见为实先看效果,您可以狠狠的点击这里:CSS3 Shapes实现列表环绕iPhone X刘海头demo

亦可以直接手机(如果是iPhone的话)扫下面二维码体验:

滚动列表,可以看到类似下面gif的效果:

环绕齐刘海滚动 实现原理

CSS Shapes中有个 CSS属性 名为 shape-outside ,可以让内联元素以不规则的形状进行外部排列,其语法如下(参考自MDN):

 /* 关键字值 */  shape-outside: none; shape-outside: m arg in-box; shape-outside: content-box; shape-outside: border-box; shape-outside: padding-box;   /* 函数值 */  shape-outside: circle(); shape-outside: ellipse(); shape-outside: inset(10px 10px 10px 10px); shape-outside: polygon(10px 10px, 20px 20px, 30px 30px);   /* <url>值 */  shape-outside: url(image.png);   /* 渐变值 */  shape-outside: linear-gra die nt(45 deg , rgba(255, 255, 255, 0) 150px,  red  150px); 

shape-outside 属性要想 生效 ,本身需要是浮动 float 元素。

本文demo效果实现使用的是 shape-outside:polygon() ,通过点坐标勾勒出和齐刘海形状相似的多边形形状,CSS代码为:

.shape {   float: left;   shape-outside: polygon(0 0, 0 150px, 16px 154px, 30px 166px, 30px 314px, 16px 326px, 0 330px, 0 0); }

如下图紫色区域示意:

此时,后面没有设置B fc (块状格式化上下文)的列表元素就会自动环绕这个形状排列,也就是自动避开了齐刘海区域。

然后,只要搞个假的iPhone X的齐刘海图片覆盖在区域上就可以了。

至此,一个静态的列表环绕齐刘海的效果就完成了。

下面关键的问题是如何让滚动的时候,列表元素动态的跟着环绕呢?

由于 shape-outside 所在的元素是浮动元素,因此,必定会跟着容器一起滚动,我们需要的效果是我们所 绘制 的这个刘海区域需要是固定的,怎么办?此时,我是借助JavaScript处理的。

原理很 简单 ,监听容器的滚动事件,让我们的 shape-outside 绘制的区域实时偏移滚动的大小。此时肉眼看上去的效果就是 shape-outside 区域 永远 固定在了滚动容器 clientH ei ght 的中间。

整个效果就这么实现了,相关JS如下:

box.addEventListener('scroll', function () {    VAR  scrollTop = box.scrollTop;    // 滚动偏移应用在shape-outside上    shape.style.shapeOutside = 'polygon(0 0, 0 '+ (150 + scrollTop) +'px, 16px '+ (154 + scrollTop) +'px, 30px '+ (166 + scrollTop) +'px, 30px '+ (314 + scrollTop) +'px, 16px '+ (326 + scrollTop) +'px, 0 '+ (330 + scrollTop) +'px, 0 0)'; });

更详尽的代码尽在demo页面。

三、CSS Shapes环绕iPhone X刘海的其它更 简易 方法

如果我们的技 术 选型是更看重简单易懂,而不是资 源 消耗与占用,还可以使用 shape-outside:url(image.png) 语法实现类似的效果,其中 'image.png' 就是用来被环绕的图片,环绕与否是基于计算alpha通道决定,用句简单的话描述,就是沿着图片非透明区域环绕。

由于使用 url() 的形状计算是基于图片元素,和 inset() , circle() , ellipse() 或者 polygon() 这些基础形状方法的计算性质不一样,因此,可以直接使用垂直 方向 的 mar gin 进行偏移。这要比 polygon() 这样实时计算坐标位置要好理解的多。

我们不妨看下CSS和JS代码,如下:

.shape {   float: left;   shape-outside: url(liu-outside.png);   margin -t op: 150px; }
box.addEventListener('scroll', function () {   var scrollTop = box.scrollTop;    // 滚动偏移应用在margin-top上    shape.style.marginTop = (150 + scrollTop) + 'px'; });

可以看到,当我们滚动容器的时候, 改变 的就一个 marginTop 值就好了;而上面的 shape-outside:polygon() 实现需要同时改变多个坐标值。

眼见为实,您可以狠狠的点击这里:shape-outside url实现列表环绕iPhone X刘海demo

如果是iPhone手机,还可以扫下面码体验:

效果类似:

有个 细节 说明
这里有个细节需要说明下,那就是作为环绕区域的图片和前面显示的那个刘海图片不是一张图片,因为我们的刘海区域需要和后面的文字有一段的间隙,因此, url(liu-outside.png) 中的这张 'liu-outside.png' 图片是有特别的实色填充处理的(扩展右侧环绕区域 尺寸 ):

四、CSS Shapes的兼容性以及结束语

CSS Shapes的兼容性为Ch rom e浏览器和Safari浏览器(包括iOS)都是支持的,也就意味着我们是可以在iPhone上使用的,完美。只是需要注意的是在iOS10.2及其之前的版本,CSS Shapes的使用还是需要加 webkit 私有前缀的,但据说iPhone X至少默认iOS 11,而刘海头交互效果就是针对iPhone X处理的,因此 webk IT 私有前缀不加也没关系。

本文这个例子可以看出知识广度的 重要 性,如果我们深究最终效果实现使用的CSS和JS代码,其实就几行代码而已,键盘敲一下,几分钟就结束了。

那为什么广大前端一看到这个效果 觉得 牛,甚至认为“UI和前端已经哭晕在厕所”呢?其实就是不 知道 CSS3 Shapes和CSS3 Regions这些与环绕布局相关的CSS属性。

所以,下班回家,经常关注一些前沿技术还是很有必要的,注意是前沿技术,不是流行技术。很多前沿技术因为使用场景小众,并不流行,甚至你可以几年项目都用不到。如果你想在技术上有所造诣,一定要摒弃功利之心,花时间 了解 之。

以上~

行文匆忙,如果有表述不准确的地方,欢迎指正。

最后感谢您花费宝贵的时间阅读本文!

(本篇完)

觉得可用,就经常来吧! 欢迎评论哦!  html5教程 ,巧夺天工,精雕玉琢。小宝典献丑了!

总结

以上是 为你收集整理的 html5教程-借助CSS Shapes实现元素滚动自动环绕iPhone X的刘海 全部内容,希望文章能够帮你解决 html5教程-借助CSS Shapes实现元素滚动自动环绕iPhone X的刘海 所遇到的问题。

如果觉得 网站内容还不错, 推荐好友。

查看更多关于html5教程-借助CSS Shapes实现元素滚动自动环绕iPhone X的刘海的详细内容...

  阅读:21次