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


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 相关文章推荐
Use Word to Search for Files
Jun 15 Javascript
javascript 数组的方法集合
Jun 05 Javascript
弹出层之1:JQuery.Boxy (一) 使用介绍
Oct 06 Javascript
Prototype源码浅析 String部分(二)
Jan 16 Javascript
查看大图功能代码jquery版
Nov 05 Javascript
JS简单实现文件上传实例代码(无需插件)
Nov 15 Javascript
Node.js(安装,启动,测试)
Jun 09 Javascript
jQuery超简单选项卡完整实例
Sep 26 Javascript
js生成随机数的过程解析
Nov 24 Javascript
解决layui追加或者动态修改的表单元素“没效果”的问题
Sep 18 Javascript
js实现幻灯片轮播图
Aug 14 Javascript
VUE-ElementUI 自定义Loading图操作
Nov 11 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
php XMLWriter类的简单示例代码(RSS输出)
2011/09/30 PHP
php解决和避免form表单重复提交的几种方法
2016/08/31 PHP
laravel 自定义常量的两种方案
2019/10/14 PHP
在 Laravel 6 中缓存数据库查询结果的方法
2019/12/11 PHP
javascript 打印页面代码
2009/03/24 Javascript
jquery 实现二级/三级/多级联动菜单的思路及代码
2013/04/08 Javascript
JavaScript中为什么null==0为false而null大于=0为true(个人研究)
2013/09/16 Javascript
Javascript闭包实例详解
2015/11/29 Javascript
全国省市二级联动下拉菜单 js版
2016/05/10 Javascript
Bootstrap风格的WPF样式
2016/12/07 Javascript
微信小程序中form 表单提交和取值实例详解
2017/04/20 Javascript
vue环境搭建简单教程
2017/11/07 Javascript
vue父组件向子组件动态传值的两种方法
2017/11/11 Javascript
基于vue 实现token验证的实例代码
2017/12/14 Javascript
jQuery Validate插件ajax方式验证输入值的实例
2017/12/21 jQuery
Vue.js上传图片到阿里云OSS存储的方法示例
2018/12/13 Javascript
Vue框架TypeScript装饰器使用指南小结
2019/02/18 Javascript
微信小程序canvas开发水果老虎机的思路详解
2020/02/07 Javascript
vue中可编辑树状表格的实现代码
2020/10/31 Javascript
Python入门篇之文件
2014/10/20 Python
用Python实现KNN分类算法
2017/12/22 Python
对Python中小整数对象池和大整数对象池的使用详解
2019/07/09 Python
python Web flask 视图内容和模板实现代码
2019/08/23 Python
解决django xadmin主题不显示和只显示bootstrap2的问题
2020/03/30 Python
解决Keras TensorFlow 混编中 trainable=False设置无效问题
2020/06/28 Python
接口自动化多层嵌套json数据处理代码实例
2020/11/20 Python
浅析与CSS3的loading动画加载相关的transition优化
2015/05/18 HTML / CSS
html5 CSS过度-webkit-transition使用介绍
2013/07/02 HTML / CSS
路易威登和香奈儿手袋:LuxeDH
2017/01/12 全球购物
试用期转正鉴定评语
2014/01/27 职场文书
企业新年寄语
2014/04/04 职场文书
三月学雷锋月活动总结
2014/04/28 职场文书
家庭聚会祝酒词
2015/08/11 职场文书
干货:我将这样书写我的演讲稿!
2019/05/09 职场文书
关于Oracle12C默认用户名system密码不正确的解决方案
2021/10/16 Oracle
公历12个月名称的由来
2022/04/12 杂记