欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 微信开发 > 黄秀杰实战教程--购物车动画与加减

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:789

HTML5自适应律师工作室类网

2020-04-04   浏览:654

高端HTML5响应式企业通用网

2020-05-06   浏览:560

html5响应式外贸网站英文版

2020-05-08   浏览:545

HTML5影视传媒文化公司类网

2020-05-12   浏览:543

黄秀杰实战教程--购物车动画与加减

发布时间:2020-12-28  

实现以下业务逻辑购物车动画购物车内加减一、购物车动画cascadeToggle: function () { //切换购物车开与关 if (that.data.maskVisual == 'show') { that.cascadeDismiss(); } else { that.cascadePopup() ...

 

 

 

实现以下业务逻辑

购物车动画

购物车内加减

一、购物车动画 cascadeToggle: function () {        //切换购物车开与关    if (that.data.maskVisual == 'show') {        that.cascadeDismiss();    } else {        that.cascadePopup();    } }, cascadePopup: function () {    // 购物车打开动画    var animation = wx.createAnimation({        duration: 500,        timingFunction: 'ease-in-out',    });    this.animation = animation;    animation.translateY(-285).step();    this.setData({        animationData: this.animation.export(),        maskVisual: 'show'    }); }, cascadeDismiss: function () {        // 购物车关闭动画    this.animation.translateY(285).step();    this.setData({        animationData: this.animation.export(),        maskVisual: 'hidden'    }); }

黄秀杰实战教程--购物车动画与加减

通过点击控制显示与隐藏,<view class="ft" bindtap="cascadeToggle">

而<view>层级通过z-index来解决,其中底部购物车.ft区别权重最高,设为999,其次是弹窗主体.modal-content,其余默认不设定。

二、购物车加减

首先要读取购物车数据,即cartData,它是以foodId为key,数量为value的object,所以需要转换为array,才能很好地被遍历。

cartToArray: function (foodId) {    // 需要判断购物车数据中是否已经包含了原商品,从而决定新添加还是仅修改它的数量    var cartData = that.data.cartData;        var cartObjects = that.data.cartObjects;        var query = new Bmob.Query('Food');        // 查询对象    query.get(foodId).then(function (food) {            // 从数组找到该商品,并修改它的数量        for (var i = 0; i < cartObjects.length; i++) {                        if (cartObjects[i].food.id == foodId) {                            // 如果是undefined,那么就是通过点减号被删完了                if (cartData[foodId] == undefined) {                   delete cartObjects[i];                } else {                    cartObjects[i].quantity = cartData[foodId];                }                that.setData({                    cartObjects: cartObjects                });                                // 成功找到直接返回,不再执行添加                return ;            }        }                // 添加商品到数组        var cart = {};        cart.food = food;        cart.quantity = cartData[foodId];        cartObjects.push(cart);        that.setData({            cartObjects: cartObjects        });    }); }

然后在add/subtract方法末尾中调用它就可以购物车键值对转换成对象数组。