微信小程序实现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 第二课 操作包装集元素代码
Mar 14 Javascript
jQuery 表单验证扩展(四)
Oct 20 Javascript
js改变文章字体大小的实例代码
Nov 27 Javascript
深入理解JavaScript系列(30):设计模式之外观模式详解
Mar 03 Javascript
关于微信jssdk实现多图片上传的一点心得分享
Dec 13 Javascript
浅谈Vue.js
Mar 02 Javascript
AngularJS之页面跳转Route实例代码
Mar 10 Javascript
理解Angular的providers给Http添加默认headers
Jul 04 Javascript
Vue实例中生命周期created和mounted的区别详解
Aug 25 Javascript
微信小程序实现列表滚动头部吸顶的示例代码
Jul 12 Javascript
通过vue刷新左侧菜单栏操作
Aug 06 Javascript
详解jQuery的核心函数和事件处理
Feb 18 jQuery
微信小程序实现两个页面传值的方法分析
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
用header 发送cookie的php代码
2007/03/16 PHP
浅谈PHP的排列组合(如输入a,b,c 输出他们的全部组合)
2017/03/14 PHP
Jquery Ajax学习实例4 向WebService发出请求,返回实体对象的异步调用
2010/03/16 Javascript
JQUERY对单选框(radio)操作的小例子
2013/04/25 Javascript
js正文内容高亮效果的实现方法
2013/06/30 Javascript
JS网页图片按比例自适应缩放实现方法
2014/01/15 Javascript
JS表的模拟方法
2015/02/05 Javascript
JS运动框架之分享侧边栏动画实例
2015/03/03 Javascript
JQuery简单实现锚点链接的平滑滚动
2015/05/03 Javascript
jQuery position() 函数详解以及jQuery中position函数的应用
2015/12/14 Javascript
简述Matlab中size()函数的用法
2016/03/20 Javascript
Bootstrap编写一个在当前网页弹出可关闭的对话框 非弹窗
2016/06/30 Javascript
jquery checkbox的相关操作总结
2016/10/17 Javascript
easyui-datagrid特殊字符不能显示的处理方法
2017/04/12 Javascript
Node.js 中使用 async 函数的方法
2017/11/20 Javascript
用jquery获取select标签中选中的option值及文本的示例
2018/01/25 jQuery
理解Koa2中的async&amp;await的用法
2018/02/05 Javascript
你可能从未使用过的11+个JavaScript特性(小结)
2020/01/08 Javascript
webpack+vue-cil 中proxyTable配置接口地址代理操作
2020/07/18 Javascript
[01:10:02]IG vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
Python模拟鼠标点击实现方法(将通过实例自动化模拟在360浏览器中自动搜索python)
2017/08/23 Python
Python实现简易Web爬虫详解
2018/01/03 Python
python使用scrapy发送post请求的坑
2018/09/04 Python
Python3 获取一大段文本之间两个关键字之间的内容方法
2018/10/11 Python
python numpy 按行归一化的实例
2019/01/21 Python
Python适配器模式代码实现解析
2019/08/02 Python
pytorch 指定gpu训练与多gpu并行训练示例
2019/12/31 Python
Python 支持向量机分类器的实现
2020/01/15 Python
政法学院毕业生求职信
2014/02/28 职场文书
股权转让协议范本
2014/12/07 职场文书
工会工作个人总结
2015/03/03 职场文书
2015年“七七卢沟桥事变”纪念活动总结
2015/03/24 职场文书
2015初中生物教研组工作总结
2015/07/21 职场文书
中国文明网2015年“向国旗敬礼”活动网上签名寄语
2015/09/24 职场文书
劳动合同变更协议书范本
2019/04/18 职场文书
Python OpenCV形态学运算示例详解
2022/04/07 Python