微信小程序动画组件(全图图标导航,下部弹出导航,左滑修改删除)

本文主要是介绍微信小程序动画组件(全图图标导航,下部弹出导航,左滑修改删除),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

所谓动画,可以用animation或者transition两种方式实现。

 

在CSS中,@keyframes根据你定义的样式规则来更有效的控制动画队列中的每一个中间步骤(或者每一个路径点)。用@keyframes来制定动画规则会比使用transition(过渡)来获得更细腻更全面的动画效果。

  • 并且现在网络上有非常多开源的CSS3动态库,可以下载源码,直接用!!!是真的,只需要把大神写好的@keyframes直接复制到css里,然后在animation中使用对应的动画名,就能直接用了!!!

  • 那咱们先来了解下@keyframes是个什么东西吧

@keyframes slidein { from { margin-left: 100%; width: 300%; }to { margin-left: 0%; width: 100%; } }
  • from为开头帧
  • to为结束帧

我们一般都采用简写的形式,一行代码将animation所有我们需要的属性设置好

@keyframes duration | timing-function | delay | iteration-count | direction | fill-mode | play-state | name

如:

animation: 3s ease-in 1s 2 reverse both paused slidein;

 

那么animation以及transition动画在微信小程序中能得到什么样的运用呢?

接下来我将拿我在开源小程序组件库ColorUI中贡献的三个动画组件例子来展示一下

 

一、全图图标导航

JS

  data: {// 全屏图标导航showFullNavigation: false,navigation1: [{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },],},clickFullNavigation: function () {this.setData({showFullNavigation: !this.data.showFullNavigation}) },

 HTML

  • 将bindtap的触发函数放在最外层,这样当出现遮罩层时,点击任意地方都可以取消,而不用专门去点一个小小的关闭按钮。
<view bindtap='clickFullNavigation'><view class="fullBox {{showFullNavigation ? 'fullBox-active':''}}'"><view class="nav-item-box" bindtap='gotoAdd'><view wx:for="{{navigation1}}"><image class="nav-item" src="{{item.src}}"/><text class='append'>{{item.name}}</text></view></view></view>
</view>

CSS

  • 用@keyframes 的from(0%)和to(100%)以及各种属性来定义animation动画,然后在css中使用animation:动画持续时间 | 动画名。
  • transform是用来设置最开始样式的偏移,transform: translateX(1000rpx);是指沿着X轴偏移1000rpx,已经在屏幕之外了,transform: translateX(0);指的是偏移为0,即原本应该在的位置。就可以出现从外面到正中央,然后再正中央,退场这样的动画了。
/* 全屏图标导航部分 */
.fullBox{position: fixed;width: 100%;background: #ffffff;height: 100%;top: 0;left: 0;right: 0;bottom: 0;z-index: 3;transform: translateX(1000rpx);animation: 0.5s spaceOutLeft;
}
.fullBox-active{transform: translateX(0);animation: 0.5s spaceInRight;
}
@keyframes spaceOutLeft {0% {opacity: 1;-webkit-transform-origin: 0% 50%;transform-origin: 0% 50%;-webkit-transform: scale(1) translate(0%, 0%);transform: scale(1) translate(0%, 0%);}100% {opacity: 0;-webkit-transform-origin: 0% 50%;transform-origin: 0% 50%;-webkit-transform: scale(.2) translate(-200%, 0%);transform: scale(.2) translate(-200%, 0%);}
}
@keyframes spaceInRight {0% {opacity: 0;-webkit-transform-origin: 100% 50%;transform-origin: 100% 50%;-webkit-transform: scale(.2) translate(200%, 0%);transform: scale(.2) translate(200%, 0%);}100% {opacity: 1;transform: translateY(0);-webkit-transform-origin: 100% 50%;transform-origin: 100% 50%;-webkit-transform: scale(1) translate(0%, 0%);transform: scale(1) translate(0%, 0%);}
}

二、下部弹出导航

  • 优点同上,感慨一下,flex布局真是个好东西,还不了解的同学可以多补补基础,可以看看阮一峰的教程
  • http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

JS

  data: {// 下部弹出导航showBottomNavigation: false,navigation2: [{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },{ name: 'Color UI', src: '/images/icon.jpg' },],},clickBottomNavigation: function () {this.setData({showBottomNavigation: !this.data.showBottomNavigation})},

HTML

<view bindtap='clickBottomNavigation'><view class="chooseBox {{showBottomNavigation ? 'chooseBox-active':''}}'"><view class="nav-item-box" bindtap='gotoAdd'><view wx:for="{{navigation2}}"><image class="nav-item" src="{{item.src}}"/><text class='append'>{{item.name}}</text></view></view></view><view class="chooseMask"  wx:if="{{showBottomNavigation}}"></view>
</view>

CSS

/* 下部弹出导航部分 */
.chooseMask{display: flex;width: 100%;height: 100%;background: rgba(0,0,0,0.7);position: fixed;top: 0;left: 0;right: 0;bottom: 0;z-index: 2;
}
.chooseBox{border-radius: 30rpx;position: fixed;bottom: -20rpx;width: 100%;background: #ffffff;height: 340rpx;transform: translateY(340rpx);transition: all 0.4s;z-index: 3;
}
.chooseBox-active{transform: translateY(0);transition: all 0.4s;z-index: 3;
}
.nav-item-box{display: flex;flex-wrap: wrap;
}
.nav-item{margin-top: 60rpx;display: block;height: 125rpx;width: 125rpx;
}
.append{display: flex;justify-content: center;
}

三、左滑进行修改删除

  • JS的监听左滑的函数可以照搬,不用深究
  • css同样采用的是transform初始偏移,然后滑动触发函数,使得偏移复位的过程。
  • transition:all 0.4s;控制的是这个偏移动画持续的时间为0.4s

JS

  data: {// 左滑删除部分的jsshowLeftScroll:false,startX: 0, startY: 0,fakeDatas: [{title:'向左滑动,查看效果',},],},clickLeftScroll: function () {this.setData({showLeftScroll: !this.data.showLeftScroll})},modify: function () {wx.showToast({title: '修改成功',})},del: function () {wx.showModal({title: '提示',content: '确定要删除这条信息?',success: function (res) {wx.showToast({title: '删除成功',})}})},// 左滑删除部分的jstouchstart: function (e) {//开始触摸时 重置所有删除this.data.fakeDatas.forEach(function (v, i) {if (v.isTouchMove)//只操作为true的v.isTouchMove = false;})this.setData({startX: e.changedTouches[0].clientX,startY: e.changedTouches[0].clientY,fakeDatas: this.data.fakeDatas})},//滑动事件处理touchmove: function (e) {var that = this,index = e.currentTarget.dataset.index,//当前索引startX = that.data.startX,//开始X坐标startY = that.data.startY,//开始Y坐标touchMoveX = e.changedTouches[0].clientX,//滑动变化坐标touchMoveY = e.changedTouches[0].clientY,//滑动变化坐标//获取滑动角度angle = that.angle({ X: startX, Y: startY }, { X: touchMoveX, Y: touchMoveY });that.data.fakeDatas.forEach(function (v, i) {v.isTouchMove = false//滑动超过30度角 returnif (Math.abs(angle) > 30) return;if (i == index) {if (touchMoveX > startX) //右滑v.isTouchMove = falseelse //左滑v.isTouchMove = true}})//更新数据that.setData({fakeDatas: that.data.fakeDatas})},// 计算滑动角度angle: function (start, end) {var _X = end.X - start.X,_Y = end.Y - start.Y//返回角度 /Math.atan()返回数字的反正切值return 360 * Math.atan(_Y / _X) / (2 * Math.PI);},
})

HTML

<view wx:if="{{showLeftScroll}}" wx:for="{{fakeDatas}}" wx:key="{{index}}" class="touch-item {{item.isTouchMove ? 'touch-move-active' : ''}}" data-index="{{index}}" bindtouchstart="touchstart" bindtouchmove="touchmove"><view class="content"><text>{{item.title}}</text></view><view class="dele" bindtap="modify" >修改</view><view class="dele" style='background-color:#c95b54;' bindtap="del">删除</view>
</view>

CSS

/* 左滑删除部分 */
.touch-item { display: flex; justify-content: space-between; width: 100%; overflow: hidden;  box-sizing: border-box;margin: 20rpx 0 6rpx 0;background: #ffffff;}
.content { height: 200rpx;width: 100%; -webkit-transition: all 0.4s;transition: all 0.4s;-webkit-transform: translateX(220rpx);transform: translateX(220rpx); background: #ffffff;margin: 30rpx 30rpx 30rpx -220rpx;padding: 30rpx;font-size: 50rpx;display: flex;align-items: center;justify-content: center;}
.touch-move-active .content,.touch-move-active .dele { -webkit-transform: translateX(0);transform: translateX(0);}
.dele {background-color: #4479b2; width: 220rpx; display: flex;flex-direction: column;align-items: center;justify-content: center; color: #fff;-webkit-transform: translateX(440rpx);transform: translateX(440rpx);-webkit-transition: all 0.4s;transition: all 0.4s;
}
.feed-item{width: 690rpx;padding: 30rpx 30rpx 10rpx 30rpx;margin: 8rpx 0 6rpx 0;background: #ffffff;
}

github地址:https://github.com/JasonLam0990/ColorUI

这篇关于微信小程序动画组件(全图图标导航,下部弹出导航,左滑修改删除)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/726221

相关文章

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

java程序远程debug原理与配置全过程

《java程序远程debug原理与配置全过程》文章介绍了Java远程调试的JPDA体系,包含JVMTI监控JVM、JDWP传输调试命令、JDI提供调试接口,通过-Xdebug、-Xrunjdwp参数配... 目录背景组成模块间联系IBM对三个模块的详细介绍编程使用总结背景日常工作中,每个程序员都会遇到bu

Linux命令rm如何删除名字以“-”开头的文件

《Linux命令rm如何删除名字以“-”开头的文件》Linux中,命令的解析机制非常灵活,它会根据命令的开头字符来判断是否需要执行命令选项,对于文件操作命令(如rm、ls等),系统默认会将命令开头的某... 目录先搞懂:为啥“-”开头的文件删不掉?两种超简单的删除方法(小白也能学会)方法1:用“--”分隔命

C#自动化实现检测并删除PDF文件中的空白页面

《C#自动化实现检测并删除PDF文件中的空白页面》PDF文档在日常工作和生活中扮演着重要的角色,本文将深入探讨如何使用C#编程语言,结合强大的PDF处理库,自动化地检测并删除PDF文件中的空白页面,感... 目录理解PDF空白页的定义与挑战引入Spire.PDF for .NET库核心实现:检测并删除空白页

uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)

《uni-app小程序项目中实现前端图片压缩实现方式(附详细代码)》在uni-app开发中,文件上传和图片处理是很常见的需求,但也经常会遇到各种问题,下面:本文主要介绍uni-app小程序项目中实... 目录方式一:使用<canvas>实现图片压缩(推荐,兼容性好)示例代码(小程序平台):方式二:使用uni

Python实现自动化删除Word文档超链接的实用技巧

《Python实现自动化删除Word文档超链接的实用技巧》在日常工作中,我们经常需要处理各种Word文档,本文将深入探讨如何利用Python,特别是借助一个功能强大的库,高效移除Word文档中的超链接... 目录为什么需要移除Word文档超链接准备工作:环境搭建与库安装核心实现:使用python移除超链接的

Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧

《Python函数的基本用法、返回值特性、全局变量修改及异常处理技巧》本文将通过实际代码示例,深入讲解Python函数的基本用法、返回值特性、全局变量修改以及异常处理技巧,感兴趣的朋友跟随小编一起看看... 目录一、python函数定义与调用1.1 基本函数定义1.2 函数调用二、函数返回值详解2.1 有返

Nginx屏蔽服务器名称与版本信息方式(源码级修改)

《Nginx屏蔽服务器名称与版本信息方式(源码级修改)》本文详解如何通过源码修改Nginx1.25.4,移除Server响应头中的服务类型和版本信息,以增强安全性,需重新配置、编译、安装,升级时需重复... 目录一、背景与目的二、适用版本三、操作步骤修改源码文件四、后续操作提示五、注意事项六、总结一、背景与

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu