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


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 相关文章推荐
Jquery选择器 $实现原理
Dec 02 Javascript
JS获取浏览器版本及名称实现函数
Apr 02 Javascript
jquery 鼠标滑动显示详情应用示例
Jan 24 Javascript
js怎么判断flash swf文件是否加载完毕
Aug 14 Javascript
javascript中实现兼容JAVA的hashCode算法代码分享
Aug 11 Javascript
微信分享的标题、缩略图、连接及描述设置方法
Oct 14 Javascript
javascript中hasOwnProperty() 方法使用指南
Mar 09 Javascript
JavaScript通过字典进行字符串翻译转换的方法
Mar 19 Javascript
详解vue项目首页加载速度优化
Oct 18 Javascript
深入理解node.js http模块
Jan 24 Javascript
JavaScript封装单向链表的示例代码
Sep 17 Javascript
Node.js 中如何收集和解析命令行参数
Jan 08 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 实用代码收集
2010/01/22 PHP
浅析PHP中strlen和mb_strlen的区别
2014/08/31 PHP
Laravel框架查询构造器 CURD操作示例
2019/09/04 PHP
jquery仿搜索自动联想功能代码
2014/05/23 Javascript
介绍一个简单的JavaScript类框架
2015/06/24 Javascript
jquery京东商城双11焦点图多图广告特效代码分享
2015/09/06 Javascript
js实现的奥运倒计时时钟效果代码
2015/12/09 Javascript
JavaScript中eval()函数用法详解
2015/12/14 Javascript
easyui combobox开启搜索自动完成功能的实例代码
2016/11/08 Javascript
Bootstrap基本组件学习笔记之列表组(11)
2016/12/07 Javascript
jQuery实现字符串全部替换的方法
2016/12/12 Javascript
Bootstrap多级菜单的实现代码
2017/05/23 Javascript
bootstrap3中container与container_fluid外层容器的区别讲解
2017/12/04 Javascript
jquery如何实现点击空白处隐藏元素
2017/12/05 jQuery
vue如何安装使用Quill富文本编辑器
2018/09/21 Javascript
layui lay-verify form表单自定义验证规则详解
2019/09/18 Javascript
基于JavaScript伪随机正态分布代码实例
2019/11/07 Javascript
vue-cli3中配置alias和打包加hash值操作
2020/09/04 Javascript
[02:09:59]火猫TV国士无双dota2 6.82版本详解(下)
2014/09/29 DOTA
Python命名空间详解
2014/08/18 Python
Python绘制KS曲线的实现方法
2018/08/13 Python
Python 简单计算要求形状面积的实例
2020/01/18 Python
使用Python操作ArangoDB的方法步骤
2020/02/02 Python
python3+selenium获取页面加载的所有静态资源文件链接操作
2020/05/04 Python
纯css3实现鼠标经过图片显示描述的动画效果
2014/09/01 HTML / CSS
HTML5开发动态音频图的实现
2020/07/02 HTML / CSS
加拿大最大的书店:Indigo
2017/01/01 全球购物
N:Philanthropy官网:美国洛杉矶基础款服装
2020/06/09 全球购物
纪检干部先进事迹材料
2014/08/23 职场文书
小学生勤俭节约演讲稿
2014/08/28 职场文书
讲文明懂礼貌演讲稿
2014/09/11 职场文书
工作收入证明模板
2014/10/10 职场文书
500字小学生检讨书
2015/02/19 职场文书
劳动合同变更协议书范本
2019/04/18 职场文书
nginx简单配置多个server的方法
2021/03/31 Servers
mysql数据库入门第一步之创建表
2021/05/14 MySQL