前言

前一阵子忙着找工作,面试过程中,碰到一个感觉比较有意思的问题,尽量多的列举出新手引导动画的实现方式, 昨天稍微总结了一下, 实现了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 = 100document.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.heightlet 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 = falsefor (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, 有动画等)
附上 源码

新手引导动画的4种实现方式 1相关推荐

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

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

  2. android旋转动画的两种实现方式

    在android开发,我们会常常使用到旋转动画,普通情况下旋转动画有两种实现方式,一种是直接通过java代码去实现,第二种是通过配置文件实现动画.以下是两种动画的基本是用法: 纯Java代码实现: / ...

  3. Web前端笔记-two.js图形旋转动画的2种实现方式

    这里有两种方式! 第一种是使用setInterval: 代码如下: let time = setInterval(function(){if(sun.sun.rotation >= TWO_PI ...

  4. android缩放动画的两种实现方法

    在android开发.我们会常常使用到缩放动画,普通情况下缩放动画有两种实现方式.一种是直接通过java代码去实现,第二种是通过配置文件实现动画,以下是两种动画的基本是用法: Java代码实现: // ...

  5. Github项目解析(九)--实现Activity跳转动画的五种方式

    2019独角兽企业重金招聘Python工程师标准>>> 版权声明:本文为博主原创文章,未经博主允许不得转载. 转载请标明出处:一片枫叶的专栏 上一篇文章中我们讲解了在Activity ...

  6. 前端实现动画的6种方式详解

    前端实现动画的6种方式详解 一.总结 一句话总结:一般是css样式改变加setInterval 二.[前端动画]实现动画的6种方式 通常在前端中,实现动画的方案主要有6种: javascript直接实 ...

  7. Flutter 平移动画 — 4种实现方式

    系列文章 Flutter 旋转动画 - RotationTransition Flutter 平移动画 - 4种实现方式 Flutter 淡入淡出与逐渐出现动画 Flutter 尺寸缩放.形状.颜色. ...

  8. css卷轴动画小程序,微信小程序动画两种实现方式

    开发小程序,实现动画功能,有两种实现方式,下面来看看具体怎么做: JS动画 利用小程序API提供的wx.createAnimation(OBJECT)实现,API中是这样说:创建一个动画实例anima ...

  9. 全网最全!!Qt实现图片旋转及图片旋转动画的几种方式

    实现图片旋转的两种方式 第一种方案 使用 QPixmap 的 transformed 函数来实现旋转,这个函数默认是以图片中心为旋转点,不能设置旋转的中心点,使用如下: QMatrix matrix; ...

最新文章

  1. 程序员如何乘风破浪?从数据库历史看技术人发展 | CSDN 高校俱乐部
  2. python读取文件-python读取大文件
  3. Spring AOP的一个简单实现
  4. 如何在云计算平台使用R语言编程的快速入门指南
  5. Git 撤销中间某次的提交记录
  6. CRNN:端到端不定长文字识别算法
  7. python用一行代码编写一个回声程序_利用Python实现一个WC程序
  8. JavaScript 本地验证用户注册信息
  9. 前端学习(2887):如何短时间内实现v-for proxy代理
  10. 利用Python进行数据分析(1) 简单介绍
  11. js调用vlc_如何使用HTML5或JavaScript查看RTSP流,而不使用Real Player插件上的VLC插件等插件?...
  12. 30秒Python轻松入门-目录
  13. ipconfig默认网关为空_网络工程师之IPCONFIG命令详解
  14. Springboot课程试题库管理系统毕业设计源码271129
  15. 【其他】电脑ADB连接手机的方式
  16. python窗口找图_python查找图片在原始图片上的坐标点
  17. 打印5列五颗星_55组“数学顺口溜” 大九九乘法口诀表!孩子想学好数学必须背熟...
  18. 使用物理学和领域知识的神经网络的无标签监督解读(上)
  19. MQ-3酒精模拟量 电压转换公式
  20. itools android玩游戏,itools模拟器能玩ios游戏吗?

热门文章

  1. 国内安装K8S镜像源
  2. linux中OpenVas 漏洞扫描软件
  3. CentOS 7 下挂载NTFS文件系统并实行开机自动挂载
  4. 【Linux】tee命令
  5. 【Python-3.5】绘制随机漫步图
  6. 【Linux】grep命令
  7. ORACLE数据库多表关联查询效率问题解决方案
  8. 关于C#关闭窗体后,依旧有后台进程在运行的解决方法
  9. 当前版本的Android Gradle插件不支持按需配置
  10. 打开模式时防止BODY滚动