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


Posted in Javascript onDecember 11, 2018

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

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

先上效果图:

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

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.5s linear ;
}
.slideup {
  animation: slideup 0.5s 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.巧用定时器设置属性值,可达到类似上面执行一个动画之后再执行另外一个动画的方法。

希望本文所述对大家微信小程序开发有所帮助。

Javascript 相关文章推荐
Jquery图片滚动与幻灯片的实例代码
Apr 08 Javascript
jQuery Ajax异步处理Json数据详解
Nov 05 Javascript
from表单多个按钮提交用onclick跳转不同action
Apr 24 Javascript
体验jQuery和AngularJS的不同点及AngularJS的迷人之处
Feb 02 Javascript
jQuery Easyui Datagrid实现单行的上移下移及保存移动的结果
Aug 15 Javascript
JavaScript实现的微信二维码图片生成器的示例
Oct 26 Javascript
JavaScript中从setTimeout与setInterval到AJAX异步
Feb 13 Javascript
jquery实现放大镜简洁代码(推荐)
Jun 08 jQuery
微信小程序录音与播放录音功能
Dec 25 Javascript
axios全局注册,设置token,以及全局设置url请求网段的方法
Sep 25 Javascript
JavaScript私有变量实例详解
Jan 24 Javascript
通过js示例讲解时间复杂度与空间复杂度
Aug 06 Javascript
微信小程序实现两个页面传值的方法分析
Dec 11 #Javascript
jQuery使用bind动态绑定事件无效的处理方法
Dec 11 #jQuery
微信小程序实现的3d轮播图效果示例【基于swiper组件】
Dec 11 #Javascript
vue-cli 3.0 版本与3.0以下版本在搭建项目时的区别详解
Dec 11 #Javascript
微信小程序非swiper组件实现的自定义伪3D轮播图效果示例
Dec 11 #Javascript
vue-cli2.0转3.0之项目搭建的详细步骤
Dec 11 #Javascript
jQuery实现点击旋转,再点击恢复初始状态动画效果示例
Dec 11 #jQuery
You might like
php的chr和ord函数实现字符加减乘除运算实现代码
2011/12/05 PHP
10个对初学者非常有用的PHP技巧
2016/04/06 PHP
判断客户端浏览器是否安装了Flash插件的多种方法
2010/08/11 Javascript
热点新闻滚动特效的js代码
2013/08/17 Javascript
查找iframe里元素的方法可传参
2013/09/11 Javascript
jQuery实现类似老虎机滚动抽奖效果
2015/08/06 Javascript
js弹出对话框方式小结
2015/11/17 Javascript
Angularjs 制作购物车功能实例代码
2016/09/14 Javascript
VueJS全面解析
2016/11/10 Javascript
vue-router路由简单案例介绍
2017/02/21 Javascript
Bootstrap3 模态框使用实例
2017/02/22 Javascript
详解Vue.js入门环境搭建
2017/03/17 Javascript
详解nodeJS之二进制buffer对象
2017/06/03 NodeJs
移动端效果之IndexList详解
2017/10/20 Javascript
聊聊JS动画库 Velocity.js的使用
2018/03/13 Javascript
vue 项目地址去掉 #的方法
2018/10/20 Javascript
JS实现图片轮播效果实例详解【可自动和手动】
2019/04/04 Javascript
axios+Vue实现上传文件显示进度功能
2019/04/14 Javascript
python3 对list中每个元素进行处理的方法
2018/06/29 Python
python中列表的切片与修改知识点总结
2019/07/23 Python
python使用minimax算法实现五子棋
2019/07/29 Python
python设置随机种子实例讲解
2019/09/12 Python
Keras设定GPU使用内存大小方式(Tensorflow backend)
2020/05/22 Python
Ubuntu20.04环境安装tensorflow2的方法步骤
2021/01/29 Python
享受加州生活方式的时尚舒适:XCVI
2018/07/09 全球购物
美国正宗奢华复古手袋、珠宝及配饰网站:What Goes Around Comes Around
2018/07/21 全球购物
以太网Ethernet IEEE802.3
2013/08/05 面试题
市场营销专业个人自荐信格式
2013/09/21 职场文书
商务英语专业应届毕业生求职信
2013/10/28 职场文书
竞职演讲稿范文
2014/01/11 职场文书
八月一日观后感
2015/06/10 职场文书
关于antd tree 和父子组件之间的传值问题(react 总结)
2021/06/02 Javascript
css3带你实现3D转换效果
2022/02/24 HTML / CSS
sql时间段切分实现每隔x分钟出一份高速门架车流量
2022/02/28 SQL Server
千万级用户系统SQL调优实战分享
2022/03/03 MySQL
Android自定义scrollview实现回弹效果
2022/04/01 Java/Android