首先,咱们看一下微信小程序动画怎么实现,我首先想到的是anime.js,但是引入之后用不了,微信小程序内的css也无法做到循环的动态,我就去找官方文档看看有没有相应的方法,哎,还真有

点击这里查看 微信官方文档

简化一下哈:就是这样的

先在js的data里面定义一个动画的值

data: {
    animationData: {},
  },
我这边做的是一个箭头图片的旋转
所以wxml里面得元素是这样的
<image animation="{{animationData}}" src="/img/arrows.png" class="arrow" alt="" bindtap="titleClick"></image>

点击生效嘛,然后js里面就在上边bindtap点击函数里面写

 titleClick: function (e) {

      let animation = wx.createAnimation({
duration: 100,//动画的时间
timingFunction: 'ease',//动画的速度
})
this.animation = animation
animation.rotate(90).step()//动画操作,旋转平移之类的自己看看文档,我这个是旋转的 this.setData({
animationData: animation.export()
}); }

这样就是一个简简单单的动画了

但是我的要求是循环列表出来的是这样的,每个单独有一个动画

点击旋转,然后下面的东西出来,再点击下面东西消失箭头旋转回来

各种百度,查资料

最后想到在吧动画这个属性

animationData由{}对象变成[]数组,然后数组里有很多个{}对象,那这样不就可以改变单独的值了么
首先data里有个数组
 data: {
    animationData: [],
    array: []//列表循环数组
  },
然后在请求之后,循环数组生成一个新的数组,里面都是空对象
var animation = []//
for (let index = 0; index < list.length; index++) {
        animation.push({})
}

//然后给data里的animationData赋值
this.setData({
        animationData: animation
      })

wxml里的代码,简单的一个列表

<view class="list" wx:for="{{array}}" wx:key="id"  wx:for-index="idx" wx:for-item="item">
<view class="title" data-id='{{idx}}' bindtap="titleClick">
<image animation="{{animationData[idx]}}" src="/img/arrows.png" class="arrow" alt="" ></image>
<text>{{item.content}}</text>
</view>
<view class="content">
{{item.content}}
</view>
</view>

data-**是可以记录当前下标,与后面animationData的下标相对应

接下来就是点击的事件了

  titleClick: function (e) {
var index = e.currentTarget.dataset.id
var temp_str = 'animationData[' + index + ']';
//设第一个动画是向下旋转,第二个动画是返回初始状态
//判断鱼当前点击的 animationData相对应的{}是否为空,如果为空就是走第一个动画,不为空走第二个
if (JSON.stringify(this.data.animationData[index]) != "{}") {
let animation = wx.createAnimation({
duration: 100,
timingFunction: 'ease',
})
this.animation = animation
animation.rotate(0).step()
this.setData({
[temp_str]: animation.export()
});//这个是为动画运行赋值,也就是返回初始状态的
this.setData({
[temp_str]: {}
});//这个是动画返回到初始后将这个animationData相对应的对象值清空,下次就会走第一个动画,不要直接清空,没有效果
} else {
let animation = wx.createAnimation({
duration: 100,
timingFunction: 'ease',
})
this.animation = animation
animation.rotate(90).step() this.setData({
[temp_str]: animation.export()
});
}
console.log(this.data.animationData); }

列表下面的显示隐藏我还没开始做,但是那个就比较简单了,后面我也不再讲了,其实这个动画逻辑理通顺了之后也是比较简单的,如果大家有其他更简单的方法也欢迎留言告诉我哦

 
 
 
 
 
 
 

微信小程序循环列表点击每一个单独添加动画的更多相关文章

  1. 微信小程序 循环列表添加点击事件和样式

    如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如 <input/> 中的输入内容,<switch/> 的选中状态),需要使 ...

  2. 微信小程序新闻列表功能(读取文件、template模板使用)

    微信小程序新闻列表功能(读取文件.template) 不忘初心,方得始终.初心易得,始终难守. 在之前的项目基础上进行修改,实现读取文件内容作为新闻内容进行展示. 首先,修改 post.wxml 文件 ...

  3. 微信小程序如何跳转到另一个小程序

    微信小程序如何跳转到另一个小程序,要注意:在app.json文件里也要配置 navigateToMiniProgramAppIdList,如下图: "navigateToMiniProgra ...

  4. 微信小程序新闻网站列表页

    在app.json中可以设置所有文件的头部导航颜色 (是window属性的子属性) 在具体页面可以单独设置该页面的导航颜色 (直接写该属性,不需要写window属性) 查看官方文档,可以看到好多全局属 ...

  5. 第一个微信小程序(实现点击一个按钮弹出toast)

    今天根据网上的教程搭建了微信小程序的环境,然后看文档做了一个简单的小应用. 项目的目录是这个样子的: app.js.app.json.app.wxss是全局文件,必不可少的文件.定义在app.wxss ...

  6. 微信小程序关于tabbar点击切换数据不刷新问题

    微信小程序中经常遇到的需求就是我提交了一个表单或者进行了一个操作,需要在我的个人中心页面中实时显示出来,但是小程序中的tabbar切换类似于tab切换 并不会进行页面刷新请求 所以总是会造成一些数据更 ...

  7. 微信小程序初见+nodejs服务端 (一个简单的博客)

    推荐网址: 腾讯云快速开发(nodejs前后端):https://developers.weixin.qq.com/miniprogram/dev/qcloud/qcloud.html#%E5%AF% ...

  8. 微信小程序开发(一)创建一个小程序Hello World!

    开发微信小程序并不是很难,网上有很多小程序开发资料,尤其是微信官方的<小程序开发指南>最详细. 下面是我开发小程序的历程: 第一步,请前往https://mp.weixin.qq.com/ ...

  9. 【微信】微信小程序 应用内的页面跳转在添加了tab以后就跳转不成功的问题解决

    在微信小程序中,本来应用页面内绑定在按钮上跳转页面可以成功,但是将页面添加在tab以后就不能实现跳转了 原本代码如下: //事件处理函数 bindViewTap: function() { wx.na ...

随机推荐

  1. m3u8文件合并处理

    m3u8文件合并处理 简介 M3U8 是 Unicode 版本的 M3U,用 UTF-8 编码."M3U" 和 "M3U8" 文件都是苹果公司使用的 HTTP ...

  2. 【KiCad镜像】下载与安装

    镜像下载.域名解析.时间同步请点击 阿里云开源镜像站 一.KiCad介绍 KiCad EDA 是一款用于印刷电路板设计的开源自由软件,基于 GPLv3 开源协议. 软件包含工程项目管理.原理图设计.线 ...

  3. 配置 conda 镜像环境

    镜像下载.域名解析.时间同步请点击 阿里巴巴开源镜像站 环境: conda/4.11.0 CPython/3.8.8 Windows/10 镜像源选用阿里云镜像站anaconda镜像:https:// ...

  4. 网络监听HTTP协议信息实验

    一.开启环境 登录web服务器,在服务器中开启phpstudy服务器环境. 在操作机中打开目标站[Web服务器IP地址]地址.安装wordpress,数据库名:wordpress,用户名root 密码 ...

  5. 如何在 Java 中实现二叉搜索树

    二叉搜索树 二叉搜索树结合了无序链表插入便捷和有序数组二分查找快速的特点,较为高效地实现了有序符号表.下图显示了二叉搜索树的结构特点(图片来自<算法第四版>): 可以看到每个父节点下都可以 ...

  6. Pytorch自动混合精度(AMP)介绍与使用

    背景: pytorch从1.6版本开始,已经内置了torch.cuda.amp,采用自动混合精度训练就不需要加载第三方NVIDIA的apex库了.本文主要从三个方面来介绍AMP: 一.什么是AMP? ...

  7. Linux 下通过ping判断机器有没有外网。(不用root)

    背景: 想实现一个判断当前系统有没有外网的方法,想到了两种思路: 1)实现一个ICMP协议.但是这个需要root权限才能运行.可以参考:https://www.cnblogs.com/xcywt/p/ ...

  8. Mysql查询优化器之基本优化

    对于一个SQL语句,查询优化器先看是不是能转换成JOIN,再将JOIN进行优化 优化分为: 1. 条件优化 2.计算全表扫描成本 3. 找出所有能用到的索引 4. 针对每个索引计算不同的访问方式的成本 ...

  9. 【Java面试宝典】说说你对 Spring 的理解,非单例注入的原理?它的生命周期?循环注入的原理, aop 的实现原理,说说 aop 中的几个术语,它们是怎么相互工作的?

    AOP与IOC的概念(即spring的核心) IOC:Spring是开源框架,使用框架可以使我们减少工作量,提高工作效率并且它是分层结构,即相对应的层处理对应的业务逻辑,减少代码的耦合度.而sprin ...

  10. pyinstaller打包Django项目

    系统:ubuntu18.04 / Centos 7自带Python3.61.安装pip3     apt-get install -y python3-pip     pip3 install --u ...