关闭

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

时间: 2018-10-08阅读: 1488标签: 动画

前言

前一阵子忙着找工作,面试过程中,碰到一个感觉比较有意思的问题,尽量多的列举出新手引导动画的实现方式, 昨天稍微总结了一下, 实现了4种.源码在最后,如果想直接看结果的,可以拉到最后去看.

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


实现一 复制目标内容

具体步骤:

  1. 用getBoundingClientRect获取目标内容的显示位置
  2. 复制一个目标内容,并且设置相对定位, 定位的数据在上一步有获取到,还要把 z-index 稍微设置高一点
  3. 在复制内容下面,加一层半透明的遮罩层.

核心代码:

let target = document.querySelector('.mid-center')
let pos = target.getBoundingClientRect()

let clone = target.cloneNode(true)

clone.style.position = 'fixed'
clone.style.left = pos.left
clone.style.top = pos.top
clone.style.width = pos.width
clone.style.height = pos.height
clone.style.zIndex = 100

document.body.appendChild(clone)

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


实现二 利用box-shadow

具体步骤:

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

核心代码:

let target = document.querySelector('.mid-center')
target.style.boxShadow = '0 0 0 4000px rgba(0, 0, 0, 0.85)'
target.style.position = 'relative'

这里设置 position:relative 是为了让 box-shadow 阴影不被父容器所挡住. 如果没有设置, box-shadow 会显示不全  

优缺点

优点: 实现方式简单易懂

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


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

具体步骤:

  1. 用getBoundingClientRect获取目标内容的显示位置
  2. html2canvas将目标内容绘制到上一步获取的指定位置和大小

核心代码:

let target = document.querySelector('.mid-center')
let pos = target.getBoundingClientRect()
let w = ~~pos.width
let h = ~~pos.height

let canvas = document.querySelector('#canvas')
canvas.width = document.documentElement.clientWidth
canvas.height = document.documentElement.clientHeight
let ctx = canvas.getContext("2d");
canvas.style.display = 'block'

html2canvas(target, {
    width: w,
    height: h,
}).then( (cvs) => {
    ctx.drawImage(cvs, pos.left, pos.top)
})

需要注意的是 这里 canvas.width 和 canvas.height 要手动设置,否则默认是 300 * 150,这样如果在样式里设置宽高的话,会导致画布被拉伸.  

优缺点

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

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


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

具体步骤:

  1. 给整个文档最外层的元素,设置一个黑色的底色
  2. 遍历整个文档,把非目标内容,和非目标内容的父容器,都设成半透明的

核心代码:

function showGuidance() {
    let main = document.querySelector('.main')
    main.className += ' darkBackGround'
    setOpticity(main)
}

function setOpticity (element) {
    let doms = Array.from(element.children) || []
    let hasMatched = false
    for (let el of doms) {
        if (!el.className.match(/mid-center/i) && el.children.length) {
            hasMatched = setOpticity(el)
        if (!hasMatched) el.className += ' halfTransparent'
        } else if(el.className.match(/mid-center/i)) {
            hasMatched = true
        } else {
            el.className += ' halfTransparent'
        }
    }
return hasMatched
}

如果不小心把目标元素的父元素也设置成半透明的,那么就算目标元素没有设置半透明,也会变透明,因为父元素里面的所有内容,都会透明  

优缺点

优点: 感觉没有优点哈

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


最后

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

作者:Noahlam
链接:http://www.imooc.com/article/247148?block_id=tuijian_wz


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/1128

关闭

CSS动画优雅降级的简单总结

可以看到动画在IE8(这里主要讨论IE)及以下完全不支持,IE9由于只支持transform(非transform3d),主要功臣自然是translate3d,因为IE9不支持自然会忽略掉,所以translate也在IE下不起效了

前端动画必知必会:React 和 Vue 都在用的 FLIP 思想实战

拿到了这个需求,第一直觉是怎么做?假设第一行第一个图片移动到了第二行第三列,是不是要计算出第一行的高度,再计算出第二行前两个元素的宽度,然后从初始的坐标点通过 CSS 或者一些动画 API 移动过去?

值得你收藏的10个CSS3动画工具

在CSS3中引入了全新的动画语法,它能够帮助你在设计中实现许多有趣的事情。通常构建炫酷的动画是非常复杂和费时的,而使用动画库和生成器则可以帮助你完美处理这一切

CSS波纹动画

以上就是css波纹动画的代码和效果图。想要看具体的效果可以复制代码浏览,当然啦,也可以设置属于自己的漂亮的背景颜色和链接。

前端开发常用css动画代码

常用的CSS动画效果,在实际开发中经常需要用到移动、大小、闪烁、渐显、渐隐等动画效果,这篇文章就整理了些常见的动画效果分享给大家,一遍收藏使用。

CSS动画的属性Transition与Animation

本文总结CSS3中两个用来做动画的属性,一个是transition,另一个是animation。transition在给定的持续时间内平滑地更改属性值(从一个值到另一个值),也就是只需要指定开始与结束的参数,参数改变时就触发动画。

css @keyframes属性 语法

@keyframes是CSS的一种规则,可以用来定义CSS动画的一个周期的行为,创建简单的动画。作用:通过 @keyframes 规则,您能够创建动画。

css3动画怎么停止?

动画是使元素从一种样式逐渐变化为另一种样式的效果。您可以改变任意多的样式任意多的次数。请用百分比来规定变化发生的时间,或用关键词 \\\"from\\\" 和 \\\"to\\\",等同于 0% 和 100%。

为什么要用css动画替换js动画?

通常我们会通过频繁的操作 DOM的CSS来实现视觉上的动画效果,导致js效率低的两个因素都包括在内了在频繁的操作DOM和CSS时,浏览器会不停的执行重排和重绘,在PC版本的浏览器中,因为浏览器可用的内存比较大

Js实现动画缓存效果

先获取要移动的元素;判断如果原本是否保存了计时器,如果有的话就立刻清空,重新启动一个新的计时器;开始计时器;每次对计算的数字进行取整 , 防止因为JavaScript精准不足而导致无限循环浪费性能

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!