• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

微信小程序之实现slideUp和slideDown效果和点击空白隐藏

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

怎样实现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.巧用定时器设置属性值,可达到类似上面执行一个动画之后再执行另外一个动画的方法。

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
微信小程序的分享功能-css文字超过两行隐藏发布时间:2022-07-18
下一篇:
微信小程序隐藏滚动条发布时间:2022-07-18
热门推荐
    热门话题
    阅读排行榜

    扫描微信二维码

    查看手机版网站

    随时了解更新最新资讯

    139-2527-9053

    在线客服(服务时间 9:00~18:00)

    在线QQ客服
    地址:深圳市南山区西丽大学城创智工业园
    电邮:jeky_zhao#qq.com
    移动电话:139-2527-9053

    Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap