微信小程序实现点击空白隐藏的方法示例


Posted in Javascript onAugust 13, 2019

怎样实现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.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 相关文章推荐
幻宇的层模拟窗口效果-提供演示和下载
Jan 20 Javascript
javascript实现的listview效果
Apr 28 Javascript
jQuery中:button选择器用法实例
Jan 04 Javascript
AngularJS实现Model缓存的方式
Feb 03 Javascript
jQuery Form插件使用详解_动力节点Java学院整理
Jul 17 jQuery
vue如何获取点击事件源的方法
Aug 10 Javascript
vue中子组件调用兄弟组件方法
Jul 06 Javascript
微信小程序传值以及获取值方法的详解
Apr 29 Javascript
微信小程序tabBar设置实例解析
Nov 14 Javascript
小程序外卖订单界面的示例代码
Dec 30 Javascript
jQuery实现简易QQ聊天框
Feb 10 jQuery
ES6使用 Array.includes 处理多重条件用法实例分析
Mar 02 Javascript
微信小程序使用npm包的方法步骤
Aug 13 #Javascript
Vue中的transition封装组件的实现方法
Aug 13 #Javascript
vue项目中使用AES实现密码加密解密(ECB和CBC两种模式)
Aug 12 #Javascript
详解json串反转义(消除反斜杠)
Aug 12 #Javascript
json 带斜杠时如何解析的实现
Aug 12 #Javascript
electron实现静默打印的示例代码
Aug 12 #Javascript
微信小程序 弹窗输入组件的实现解析
Aug 12 #Javascript
You might like
咖啡知识大全
2021/03/03 新手入门
关于mysql字符集设置了character_set_client=binary 在gbk情况下会出现表描述是乱码的情况
2013/01/06 PHP
PHP zip扩展Linux下安装过程分享
2014/05/05 PHP
浅析Yii2缓存的使用
2016/05/10 PHP
基于jQuery的合并表格中相同文本的相邻单元格的代码
2011/04/06 Javascript
jquery实现图片左右间隔滚动特效(可自动播放)
2013/05/08 Javascript
JS字符串处理实例代码
2013/08/05 Javascript
JavaScript charCodeAt方法入门实例(用于取得指定位置字符的Unicode编码)
2014/10/17 Javascript
使用Jquery实现每日签到功能
2015/04/03 Javascript
js中利用cookie实现记住密码功能
2020/08/20 Javascript
javascript实现无法关闭的弹框
2016/11/27 Javascript
详解JavaScript中return的用法
2017/05/08 Javascript
详解如何在你的Vue项目配置vux
2018/06/04 Javascript
jQuery实现网页拼图游戏
2020/04/22 jQuery
通过实例了解js函数中参数的传递
2019/06/15 Javascript
解决layui的form里的元素进行动态生成,验证失效的问题
2019/09/14 Javascript
Vue 实现从小到大的横向滑动效果详解
2019/10/16 Javascript
[01:28:24]NAVI vs VG Supermajor 败者组 BO3 第三场 6.5
2018/06/06 DOTA
Python实现的简单万年历例子分享
2014/04/25 Python
python实现读Excel写入.txt的方法
2018/04/29 Python
python flask框架实现重定向功能示例
2019/07/02 Python
Python 项目转化为so文件实例
2019/12/23 Python
django ORM之values和annotate使用详解
2020/05/19 Python
Python生成随机验证码代码实例解析
2020/06/09 Python
使用python批量修改XML文件中图像的depth值
2020/07/22 Python
解决Pyinstaller打包软件失败的一个坑
2021/03/04 Python
canvas与html5实现视频截图功能示例
2016/12/15 HTML / CSS
HTML5中图片之间的缝隙完美解决方法
2017/07/07 HTML / CSS
英国最大的香水商店:The Fragrance Shop
2018/07/06 全球购物
美国快时尚彩妆品牌:Winky Lux(透明花瓣润唇膏)
2018/11/06 全球购物
The Body Shop美体小铺西班牙官网:天然化妆品
2019/06/21 全球购物
什么是属性访问器
2015/10/26 面试题
药品促销活动方案
2014/02/14 职场文书
《盘古开天地》教学反思
2014/02/28 职场文书
女方家长婚礼答谢词
2015/09/29 职场文书
小学生优秀作文范文(六篇)
2019/07/10 职场文书