本文实例讲述了微信小程序实现slideUp、slideDown滑动效果及点击空白隐藏功能。分享给大家供大家参考,具体如下:

怎样实现jq中的slideUp或者slideDown这种动画效果呢,我的思路是用css3的transform: translateY() 属性,给需要动画的元素添加上一个动画class。

1.蒙层的结构:

`<!-- 购物车蒙层 -->`
`<``view` `class``=``'list-fix'` `wx:if``=``"{{mengShow}}"` `bindtap``=``'outbtn'``>` `<!--mengShow是蒙层是否显示的标志,然后蒙层绑定outbtn的点击事件-->`
`<``view` `class``=``'in-list {{aniStyle?"slideup":"slidedown"}}'` `catchtap``=``'inbtn'``>` `<!--这里的三元运算符是判断动画该执行哪一种,catchtap这个是阻止冒泡的点击事件,这个事件必须有,才能阻止冒泡 -->`
`<``view` `class``=``'in-content'``>`
`<``text``>已选商品(1)</``text``>`
`<``text` `class``=``'iconfont icon-6'``>清空购物车</``text``>`
`</``view``>`
`<``view` `class``=``'cho-list'` `wx:for``=``"{{chooseList}}"` `wx:key``=``""``>`
`<``view` `class``=``'listName'``>{{item.Cname}}</``view``>`
`<``view` `class``=``'listPrice'``>¥{{item.Cprice}}</``view``>`
`<``view` `class``=``'opBtn'``>`
`<``view` `class``=``'com-btn cuts'` `>-</``view``>`
`<``view` `class``=``'com-num'``>{{item.Cnum}}</``view``>`
`<``view` `class``=``'com-btn add'` `>+</``view``>`
`</``view``>`
`</``view``>`
`</``view``>`
`</``view``>`
复制代码

注意:三元运算符里的slideup和slidedown一定要加上引号

2.蒙层的其它样式自己写。最主要的是slideup和slidedown的动画效果的样式:

`@keyframes slidedown {`
`from {`
`transform: translateY(``0``);`
`}`
`to {`
`transform: translateY(``100%``);`
`}`
`}`
`.slidedown {`
`animation: slidedown` `0.5``s linear ;`
`}`
`.slideup {`
`animation: slideup` `0.5``s linear ;`
`}`
`@keyframes slideup {`
`from {`
`transform: translateY(``100%``);`
`}`
`to {`
`transform: translateY(``0``);`
`}`
`}`
复制代码

其它的样式:list-fix是fixed定位,而in-list是absolute定位。

需要注意的一点是:做的时候,是从Y轴100%的位置处即最底部开始运动或是从0到100%,所以要设置z-index,才能实现在底部运动起来的时候或者回到100%即底部的时候,蒙层浮在“确认下单”这整个结构的下面。即“确认下单”这整个结构的z-index要大于蒙层的z-index。

3.js

`page({`
`data: {`
`mengShow:``false``,``//蒙层的显示与否`
`aniStyle:``true``,` `//动画效果,默认slideup`
`},`
`//蒙层的显示`
`showMeng:``function``(e){` `//这是“确认下单”这整个购物车导航栏的点击事件`
`this``.setData({`
`mengShow:``true``,` `//蒙层显示`
`aniStyle:``true``//设置动画效果为slideup`
`})`
`},`
`outbtn:``function``(e){` `//这是list-fix的点击事件,给它绑定事件,是为了实现点击其它地方隐藏蒙层的效果`
`var` `that=``this``;`
`this``.setData({`
`aniStyle:``false``//设置动画效果为slidedown`
`})
`setTimeout(``function``(){` `//延时设置蒙层的隐藏,这个定时器的时间,就是slidedown在css动画里设置的时间,这样就能实现slidedown动画完成后,蒙层才消失的效果。不设置定时器会导致动画效果看不见`
`that.setData({`
`mengShow:` `false`
`})`
`},500)`
`},`
`inbtn:``function``(e){` `//这个事件必须有,就算不做什么事情也要写上去,因为这个事件是为了防止事件冒泡,导致点击in-list这里面的元素时,点击事件冒泡到list-fix触发它的slidedown事件。`
`console.log(``"in"``)`
`},`
`})`
复制代码

这样就能实现slidedown和slideup,点击其它地方隐藏某元素的功能了。

总结:

1.防止冒泡的点击事件:catchtap=""

2.点击父元素除子元素以外的其它地方隐藏父元素的方法:父元素绑定一个点击隐藏事件,然后子元素绑定catchtap这种能阻止冒泡的事件

3.巧用定时器设置属性值,可达到类似上面执行一个动画之后再执行另外一个动画的方法。

希望本文所述对大家微信小程序开发有所帮助。
本次给大家推荐一个交流圈,里面概括移动应用网站开发,css,html,webpack,vue node angular以及面试资源等。
对web开发技术感兴趣的同学,欢迎加入:582735936,不管你是小白还是大牛我都欢迎,还有大牛整理的一套高效率学习路线和教程与您免费分享,同时每天更新视频资料。
最后,祝大家早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

微信小程序实现slideUp、slideDown滑动效果及点击空白隐藏功能示例相关推荐

  1. 微信小程序实现slideUp、slideDown滑动效果及点击空白隐藏功能示例 1

    本文实例讲述了微信小程序实现slideUp.slideDown滑动效果及点击空白隐藏功能.分享给大家供大家参考,具体如下: 怎样实现jq中的slideUp或者slideDown这种动画效果呢,我的思路 ...

  2. 微信小程序星星评价,滑动星星评价+点击星星评价效果

    思路:点击星星评价就不用说了,度娘上多得是.我们来说一说滑动评价效果. 1.利用小程序的bindtouchmovechu事件,不知道是啥的,点击这里:https://blog.csdn.net/cra ...

  3. 微信小程序 顶部搜索框滑动伸缩效果的实现

    项目场景:微信小程序顶部搜索框随页面滑动伸缩效果 提示:实现搜索框跟随用户滑动页面,实现伸缩效果 微信小程序 顶部搜索框滑动伸缩动画的实现 实现效果: 滑动前 滑动后 实现原理 提示:主要用到了微信小 ...

  4. 微信小程序开发实现图片滚动效果

    微信小程序开发实现图片滚动效果 效果:左右滑动可以切换展示图片 代码: <!--pages/test/test.wxml--> <!-- 组件 --> <swiper&g ...

  5. c语言小程序跑马灯,微信小程序实现文字跑马灯效果

    本文实例为大家分享了微信小程序实现文字跑马灯的具体代码,供大家参考,具体内容如下 wxml 1 显示完后再显示 Box"> 2 出现白边后即显示 Box"> {{tex ...

  6. 微信小程序禁止页面左右滑动

    微信小程序禁止页面左右滑动 小程序禁止页面左右滑动 PS:在开发过程中可能会遇到某一个页面可以左右滑动,在开发者工具是查看不出来,只有在手机预览才可以看的出来(尝试左或者右滑动). 我的解决方法是在根 ...

  7. ar 微信小程序_微信小程序可支持实现AR效果

    原标题:微信小程序可支持实现AR效果 微信官方公众号"微信公开课"发文称,今天起,小程序可实现AR效果了,包括了:AR试穿.AR逛展等等.其中,首个支持AR动态试妆的美妆品牌小程序 ...

  8. 多分类经典语录微信小程序源码下载支持一键复制带壁纸,王者改名等功能

    这是一款主要以各类语录分享的一款小程序源码 比如有:舔狗日记,土味情话,别味情话,励志鸡汤 内容支持一键复制分享,可以随时切换下一个内容 另外还有壁纸功能(属于自动采集) 还有王者荣耀空白名修改,重复 ...

  9. (已更新)多分类经典语录微信小程序源码下载支持一键复制带壁纸,王者改名等功能

    这是一款主要以各类语录分享的一款小程序源码 比如有:舔狗日记,土味情话,别味情话,励志鸡汤 内容支持一键复制分享,可以随时切换下一个内容 另外还有壁纸功能(属于自动采集) 还有王者荣耀空白名修改,重复 ...

最新文章

  1. 提分策略:数据采样方法最全总结!
  2. 爬虫学习 pyspider和scrapy小结 / 与其他工具对比
  3. win10家庭版通过命令gpedit.msc打不开组策略的解决方法
  4. Linux 中模拟延时和丢包的实现
  5. java-jpa-criteriaBuilder使用入门
  6. SAP ABAP实用技巧介绍系列之 ABAP XSLT 定义变量
  7. 编译原理—语法分析器(Java)
  8. 网站程序安全分析器 VB源码
  9. 赋能尖端科技 推进智能布局 |《HPC高性能计算数据存储解决方案蓝皮书》正式发布
  10. flutter listview 滚动到指定位置_Flutter 布局原理及实战
  11. 1.1.0-简介-P4-一致性、2PC和3PC
  12. python语言的主网址-python如何获得一个url地址对应的跳转后的最终网址
  13. maven 把依赖包一起打包
  14. 软件测试工具大全(这可能是目前为止最全的测试工具集合)
  15. 学术英语理工(第二版)Unit6课文翻译
  16. web4.0之万能密码登录
  17. SDUST 第四次实验
  18. linux系统有什么用
  19. 求助:MATLAB中实现卷积运算和理论分析中的卷积运算有什么区别?
  20. 从陶潜的“化”到王维的“空”

热门文章

  1. boost::math::chi_squared用法的测试程序
  2. boost::local_time模块实现自纪元以来的秒数的测试程序
  3. boost::noinit_adaptor用法实例
  4. Boost:异步操作,需要boost :: asio :: async_initiate函数的测试程序
  5. VTK:图表之LabelVerticesAndEdges
  6. OpenCV HDF读写属性
  7. Qt Creator配置编辑器
  8. OpenGL Gamma校正 (Gamma Correction)
  9. C++实现计数排序(附完整源码)
  10. QML基础类型之var