JS 的平凡之路--学习人气眼中的效果(上)

最近看了看人气眼的界面,感觉到学习的地方有很多呀。这里先带大家看看人气值跳动的实现。本篇代码基于Vue2.x.x。

一、概要

  首先看一下效果图:

人气值动画

  要想实现上面的效果,我们分为这几个部分:

  • 判断元素是否在可视区域内;
  • 函数节流的使用;
  • 元素高度过渡动画;
  • 数字跳动动画;

二、判断元素是否在可视区域之内

  首先我们要先获取元素的位置信息,这里我们采用getBoundingClientRect方法,MDN上对于该方法的介绍。然后我们只要与可视区域做个比较,就OK了。

    // methodsisElementInViewport (el, offset) {const h = offset || 20,box = el.getBoundingClientRect(),top = (box.top >= 0),left = (box.left >= 0),bottom = (box.bottom <= (window.innerHeight || document.documentElement.clientHeight)   h),right = (box.right <= (window.innerWidth || document.documentElement.clientWidth)   h);return (top && left && bottom && right);}

三、函数节流的使用

  接下来我们需要监听'scroll'事件,判断元素是否出现在可视区域内。对于scroll事件的优化之一,我们需要使用函数节流。你可以选择导入underscore.js的throttle函数,但是这里我尝试了一下requestAnimationFrame来实现函数节流:

    //mounted: document.addEventListener('scroll', this.onScroll , false);// methods:onScroll (e) {if (!this.LOCK) {this.LOCK = true;window.requestAnimationFrame(this.scrollAction);}},scrollAction () {const flag = this.isElementInViewport(this.$refs.zfbitem, 100);if (!flag) {this.LOCK = false;} else {//触发元素高度过渡动画this.active = true;//去除掉事件监听document.removeEventListener('scroll', this.onScroll , false);}}

四、元素的高度过渡动画

  在CSS当中,实现一种动画效果,你可以有很多种方式,这里我也就不一一枚举了,此例子中我采用高度过渡的方式实现效果。有人就会说通过高度过渡没有任何难度啊?实际上,你需要注意的点还是蛮多的:

  • 想让一个元素的高度为0,并不是简单的height:0;就能做到的,前提是你不能设置border、垂直方向的padding等;
  • 当你的元素设置height为100px时,你再设置max-height为0,它一样只显示0的高度;
  • 当height的值为auto时,我们是无法过渡的。所以对于auto的情况,我们可以采用max-height来模拟一下,一般情况下,效果还行。

  实现的代码还是很简单的,这里就不贴代码了。

五、数字跳动动画

  首先我们需要在高度过渡动画完成后执行数字跳动动画,这里我们需要监听'transitionend'事件,对于这个事件需要特别注意的点:

  • 每个过渡属性完成后多会触发一次transitionend;
  • transitionend事件支持冒泡,如果子元素也有过渡效果的话,一定要阻止冒泡。
    // watch : active (newValue) {if (newValue) {this.$refs.zfbitem.addEventListener('transitionend', this.transitionAction, false);}}// methods:transitionAction (e) {//不再需要监听时,一定要移除监听this.$refs.zfbitem.removeEventListener('transitionend', this.transitionAction, false);this.numberBounce();}

  对于数字跳动的动画,正好利用了Vue响应式的特性偷懒了一波,感觉实现的还是有些生硬,我主要是从这几个方面下手的:

  • 暂且默认两位数;
  • 个位和十位多需要先跳一轮0~9,然后再跳向最终的数字,这样避免特殊的情况;
  • 个位和十位动画执行的时长是一样的,通过时长和各自需要跳动的字数,计算出每一帧需要的时间。
    //组件需要传入的参数props: {rate: Number}//分割个位 和 十位computed: {numberArray () {return (this.rate   '').split('');}}numberBounce () {let arr = this.numberArray,totalTime = 200,a = arr[1],aLen = Number.parseInt(a),aTime = Math.floor(totalTime / (aLen   9)),i = 0,b = arr[0],bLen = Number.parseInt(b),bTime = Math.floor(totalTime / (bLen   9)),j = 0;this.bit = 0;this.ten = 0;this.bitTimeId = setInterval(_ => {i  ;this.bit = i % 10; // 计数if (i - 10 === aLen) {//千万不要忘记清除定时器哦clearInterval(this.bitTimeId);this.bitTimeId = null;}}, aTime);this.tenTimeId = setInterval(_ => {j  ;this.ten = j % 10;if (j - 10 === bLen) {clearInterval(this.tenTimeId);this.tenTimeId = null;}}, bTime);}

六、总结

  这虽然是一个简单的效果,但是包含的知识点很多,这里又要强调了:基础很是重要,千万不要浮躁。(^_^)


  喜欢本文的小伙伴们,欢迎关注我的订阅号超爱敲代码,查看更多内容.


更多专业前端知识,请上 【猿2048】www.mk2048.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/366732.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[译] Airbnb 在 React Native 上下的赌注(一):概述

原文地址&#xff1a;React Native at Airbnb原文作者&#xff1a;Gabriel Peal译文出自&#xff1a;掘金翻译计划本文永久链接&#xff1a;https://github.com/xitu/gold-miner/blob/master/TODO1/react-native-at-airbnb.md译者&#xff1a;ALVINYEH校对者&#xff1a;ChenDo…

批处理最佳做法

大多数应用程序至少具有一个批处理任务&#xff0c;在后台执行特定的逻辑。 编写批处理作业并不复杂&#xff0c;但是您需要了解一些基本规则&#xff0c;我将列举一些我发现最重要的规则。 从输入类型的角度来看&#xff0c;处理项目可以通过轮询处理项目存储库来实现&#x…

android 360度视频播放器,Android开发VR实战之播放360度全景视频

VR即Virtual Reality虚拟现实。虚拟现实技术是一种可以创建和体验虚拟世界的计算机仿真系统它利用计算机生成一种模拟环境是一种多源信息融合的交互式的三维动态视景和实体行为的系统仿真使用户沉浸到该环境中。那么&#xff0c;如何在Android中去开发VR功能的APP呢&#xff1f…

关于怎么在手机端实现一个拖拽的操作

手机端&#xff0c;肯定是监听touchstart,touchmove,touchend事件 先来看看效果 当拖拽时&#xff0c;拖拽到哪个节点下面&#xff0c;就把哪个节点添加到这个下面 <div>1111</div><div>2222</div><div>3333</div><div>4444</div…

物联网架构成长之路(24)-Docker练习之Compose容器编排

0.前言  一开始学的之后&#xff0c;是想一步到位直接上Kubernetes(K8s)的&#xff0c;后面没想到&#xff0c;好像有点复杂&#xff0c;有些概念不是很懂。因此学习东西还是要循序渐进&#xff0c;慢慢来。先了解单机编排技术Docker Compose&#xff0c;了解一些技术细节及原…

CSS原理解析之模型篇

写在前面&#xff1a;尝试回答几个问题&#xff1a;什么是盒模型&#xff0c;控制盒模型的属性有哪些&#xff1f;Margin、Padding、Border、Width、Height这些属性改变/影响盒模型&#xff0c;但每个属性都会在所有元素上生效么&#xff1f;如果存在区别&#xff0c;那么和元素…

Quartz遇到的问题

本文首次发布于My Blog,作者张琦(Ian),转载请保留原文链接。 有状态和无状态 使用有状态&#xff08;StatefulJob&#xff09;还是无状态的任务&#xff08;Job&#xff09; 在 Quartz 中&#xff0c;基本来说&#xff0c;任务分为有状态和无状态两种。实现 Job 接口的任务缺省…

RIP RETE时间获得PHREAKY

我刚刚完成了我称为PHREAK的新规则算法的一些高级文档&#xff0c;这是混合推理中的一个文字游戏。 它仍然有点粗糙和高水平&#xff0c;但希望仍然很有趣。 它建立在ReteOO之上&#xff0c;非常好阅读。 ReteOO算法 ReteOO是在3、4和5系列发行版中开发的。 它采用RETE算法并应…

Hadoop自学笔记(三)MapReduce简单介绍

1. MapReduce Architecture MapReduce是一套可编程的框架&#xff0c;大部分MapReduce的工作都能够用Pig或者Hive完毕。可是还是要了解MapReduce本身是怎样工作的&#xff0c;由于这才是Hadoop的核心&#xff0c;而且能够为以后优化和自己写做准备。 Job Client, 就是用户 Job …

VirtualDOM与diff(Vue实现)

写在前面 因为对Vue.js很感兴趣&#xff0c;而且平时工作的技术栈也是Vue.js&#xff0c;这几个月花了些时间研究学习了一下Vue.js源码&#xff0c;并做了总结与输出。文章的原地址&#xff1a;https://github.com/answershuto/learnVue。在学习过程中&#xff0c;为Vue加上了…

使用Java的RESTful Web服务

REST代表“代表性状态转移”&#xff0c;由Roy Fielding于2000年在其论文“建筑风格和基于网络的软件体系结构设计”中首次提出。 REST是一种建筑风格。 HTTP是一种协议&#xff0c;其中包含一组REST体系结构约束。 REST基础 REST中的所有内容都被视为资源。 每个资源都由UR…

windows npm安装webpack

Webpack: Webpack 是一个前端资源加载/打包工具。 它将根据模块的依赖关系进行静态分析&#xff0c;然后将这些模块按照指定的规则生成对应的静态资源。 参考下图&#xff1a; 安装Webpack: 1.首先需要安装node.js&#xff08;npm&#xff09; 下载地址&#xff1a;node.js dow…

JavaFX中的塔防

我想长时间使用我的游戏引擎来编写《塔防》游戏&#xff0c;但是由于另一个小组努力创建JavaFX《塔防》游戏&#xff0c;所以我认为我宁愿创建另一款游戏。 从邮件列表中&#xff0c;我了解到不再开发其他游戏。 因此&#xff0c;我决定尝试一下。 塔防是一款非常适合基于图块…

CSS pointer-events属性的使用

楔子 在前端的开发中&#xff0c;我们都是直接与用户接触&#xff0c;应该尽量让用户感到操作畅快愉悦&#xff0c;获得类似native的感觉。其中动画是最常用的方法。 这里的需求是&#xff0c;弹层的设计&#xff0c;这个弹层希望可以像 native 上的弹层一样&#xff0c;点击…

深入理解JavaScript之Event Loop

前言 最近阅读《高性能JavaScript》时&#xff0c;第六章谈到“通过定时器将JavaScript执行代码的控制权先让给浏览器用于更新UI状态&#xff0c;然后再将控制权交回给JavaScript代码&#xff0c;这样就可以使得页面更为流畅”&#xff0c;就联想到了之前理解的事件循环。 这…

使用EasyPoi导出Excel

Excel模板来自自己写死的一个excel模板&#xff0c;相当于是用户查询数据&#xff0c;数据填充到一个模板的Excel里&#xff0c;再导出Excel /*创建模板*/String a request.getSession().getServletContext().getRealPath("/resource/河南能源化工集团安全监控系统联网系统…

Hazelcast入门

7月&#xff0c;我写了一个博客向Java开发人员介绍erlang&#xff0c;重点介绍了这两种语言之间的一些异同。 erlang虚拟机具有许多令人印象深刻的内置功能&#xff0c;其中之一是它们独立于位置并且可以互相通信。 这意味着可以通过编写很少的代码行在VM之间同步数据。 如果您…

android手机最低内存,原神手机端需要哪些配置 手机端最低配置要求介绍

原神是一款由米哈游自主研发的全新开放世界冒险游戏&#xff0c;游戏最近迎来了pc端的首次测试&#xff0c;而且在不久之后就会开启原神手机端的公测版本&#xff0c;那么手机端需要什么配置呢&#xff1f;小编带来了详细的介绍。移动端预下载&#xff1a;9月25日下午16&#x…

AnswerOpenCV一周佳作欣赏(0615-0622)

一、How to make auto-adjustments(brightness and contrast) for image Android Opencv Image Correctionim using OpenCV for Android. I would like to know,how to make image correction(auto adjustments of brightness/contrast) for image(bitmap) in android via Open…

所有其他指标均无用

对于队列&#xff0c;无论是实现为JMS &#xff0c;数据库表&#xff08;即Ruby的Delayed :: Job用于队列的什么&#xff09;&#xff0c;甚至是Amazon的SQS &#xff0c;用于评估队列状态的最常见指标是其长度。 从本质上讲&#xff0c;可以基于在任何给定时间队列中驻留多少消…