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


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 相关文章推荐
ext 代码生成器
Aug 07 Javascript
Ext grid 添加右击菜单
Nov 26 Javascript
jquery动态改变onclick属性导致失效的问题解决方法
Dec 04 Javascript
js window.open弹出新的网页窗口
Jan 16 Javascript
jQuery根据ID获取input、checkbox、radio、select的示例
Aug 11 Javascript
AngularJS实践之使用NgModelController进行数据绑定
Oct 08 Javascript
jQuery中 bind的用法简单介绍
Feb 13 Javascript
详解Vue组件插槽的使用以及调用组件内的方法
Nov 13 Javascript
Vue源码中要const _toStr = Object.prototype.toString的原因分析
Dec 09 Javascript
刷新页面后让控制台的js代码继续执行
Sep 20 Javascript
Vue解决移动端弹窗滚动穿透问题
Dec 15 Vue.js
使用Cargo工具高效创建Rust项目
Aug 14 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 xml留言板 xml存储数据的简单例子
2009/08/24 PHP
解析mysql 表中的碎片产生原因以及清理
2013/06/22 PHP
PHP页面输出时js设置input框的选中值
2016/09/30 PHP
PHP检查文件是否存在,不存在自动创建及读取文件内容操作示例
2020/01/23 PHP
php让json_encode不自动转义斜杠“/”的方法
2020/04/27 PHP
javascript应用:Iframe自适应其加载的内容高度
2007/04/10 Javascript
js加解密 脚本解密
2008/02/22 Javascript
jQuery ajax cache缓存问题
2010/07/01 Javascript
js中判断文本框是否为空的两种方法
2011/07/31 Javascript
浅谈javascript事件取消和阻止冒泡
2015/05/26 Javascript
详解JavaScript中的Unescape()和String() 函数
2015/11/09 Javascript
浅析Javascript ES6新增值比较函数Object.is
2016/08/24 Javascript
JavaScript浏览器对象模型BOM(BrowserObjectModel)实例详解
2016/11/29 Javascript
js实现下拉框效果(select)
2017/03/28 Javascript
jQuery初级教程之网站品牌列表效果
2017/08/02 jQuery
在vue中利用全局路由钩子给url统一添加公共参数的例子
2019/11/01 Javascript
用webAPI实现图片放大镜效果
2020/11/23 Javascript
基于vue的video播放器的实现示例
2021/02/19 Vue.js
Python学习笔记整理3之输入输出、python eval函数
2015/12/14 Python
python如何在列表、字典中筛选数据
2018/03/19 Python
使用 Visual Studio Code(VSCode)搭建简单的Python+Django开发环境的方法步骤
2018/12/17 Python
Python导入模块包原理及相关注意事项
2020/03/25 Python
在keras中实现查看其训练loss值
2020/06/16 Python
Tensorflow中批量读取数据的案列分析及TFRecord文件的打包与读取
2020/06/30 Python
浅析Python 条件控制语句
2020/07/15 Python
python实现AdaBoost算法的示例
2020/10/03 Python
Python数据分析库pandas高级接口dt的使用详解
2020/12/11 Python
Python实现我的世界小游戏源代码
2021/03/02 Python
Html5应用程序缓存(Cache manifest)
2018/06/04 HTML / CSS
澳大利亚珠宝商:Shiels
2019/10/06 全球购物
《长江之歌》教学反思
2014/04/17 职场文书
爱与责任师德演讲稿
2014/08/26 职场文书
综合素质评价思想道德自我评价
2015/03/09 职场文书
怎样写好演讲稿题目?
2019/08/21 职场文书
ORACLE数据库应用开发的三十个注意事项
2021/06/07 Oracle
Python实现Matplotlib,Seaborn动态数据图
2022/05/06 Python