美文网首页让前端飞
新手引导动画的4种实现方式

新手引导动画的4种实现方式

作者: 强哥科技兴 | 来源:发表于2018-12-17 10:58 被阅读0次

    前言

    这里假设所有的弹出层都是基于页面上原有的元素

    实现一 复制目标内容

    具体步骤:

    用getBoundingClientRect获取目标内容的显示位置

    复制一个目标内容,并且设置相对定位, 定位的数据在上一步有获取到,还要把 z-index 稍微设置高一点

    在复制内容下面,加一层半透明的遮罩层.

    核心代码:

    优缺点

    比较平凡的实现方式,普普通通的,没啥特色.

    实现二 利用box-shadow

    具体步骤:

    设置目标对象的 box-shadow 为一个比较大的,半透明的值

    设置目标对象的 position 为 relative

    核心代码:

    优缺点

    优点: 实现方式简单易懂

    缺点: box-shadow 是个比较耗性能的属性, 而且依靠 position:relative 不知道会不会出现无法覆盖的问题

    实现三 利用 html2canvas 将目标内容绘制的一个底色半透明的 canvas 里面

    具体步骤:

    用getBoundingClientRect获取目标内容的显示位置

    用html2canvas将目标内容绘制到上一步获取的指定位置和大小

    核心代码:

    优点: 性能应该相对会比较好一点(如果html2canvas性能内有太差的话), 用 canvas 实现, 也比较不容易碰到各种层级遮挡或显示不全的问题.

    缺点: 实现方式相对繁琐一点,而且需要借助外部工具

    实现四 把其他元素都设成半透明的.然后给 body 加一个黑色的底色

    具体步骤:

    给整个文档最外层的元素,设置一个黑色的底色

    遍历整个文档,把非目标内容,和非目标内容的父容器,都设成半透明的

    核心代码:

    优缺点

    优点: 感觉没有优点哈

    缺点: 批量操作 dom, dom 元素多的情况下,性能极差

    最后

    以上所有实现方式,均按最简单的实现方式来,未考虑一些特殊情况(如:resize, 有动画等)

    最后:“相信有很多想学前端的小伙伴,今年年初我花了一个月整理了一份最适合2018年学习的web前端干货,从最基础的HTML+CSS+JS到移动端HTML5等都有整理,送给每一位前端小伙伴,53763,1707这里是小白聚集地,欢迎初学和进阶中的小伙伴。”

    祝大家早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

    相关文章

      网友评论

        本文标题:新手引导动画的4种实现方式

        本文链接:https://www.haomeiwen.com/subject/cgjqkqtx.html