四时宝库

程序员的知识宝库

微信小程序实现购物车页面(续二)(小程序购物车的实现)

1.2 集成WXStepper

1.2.1 复制组件内容

将stepper.wxss的内容复制到cart.wxss中

将stepper.wxml的内容复制到cart.wxml中

与之前的单一组件不同的是:这里要定义数组minusStatuses来与每一个加减按钮相应。当然,合并入carts也是没问题的。

minusStatuses: ['disabled', 'disabled', 'normal', 'normal', 'disabled']

原来的静态字符WXStepper换成以下的代码

<view class="stepper">

<!-- 减号 --> <text class="{{minusStatuses[index]}}" data-index="{{index}}" bindtap="bindMinus">-</text>

<!-- 数值 --> <input type="number" bindchange="bindManual" value="{{item.num}}" />

<!-- 加号 --> <text class="normal" data-index="{{index}}" bindtap="bindPlus">+</text>

</view>

js代码bindMinus、bindPlus分别改造为如下:

bindMinus: function(e) {

var index = parseInt(e.currentTarget.dataset.index);

var num = this.data.carts[index].num; // 如果只有1件了,就不允许再减了

if (num > 1) {

num --;

}

// 只有大于一件的时候,才能normal状态,否则disable状态

var minusStatus = num <= 1 ? 'disabled' : 'normal';

// 购物车数据

var carts = this.data.carts;

carts[index].num = num;

// 按钮可用状态

var minusStatuses = this.data.minusStatuses;

minusStatuses[index] = minusStatus;

// 将数值与状态写回

this.setData({

carts: carts,

minusStatuses: minusStatuses

});

},

bindPlus: function(e) {

var index = parseInt(e.currentTarget.dataset.index);

var num = this.data.carts[index].num; // 自增

num ++;

// 只有大于一件的时候,才能normal状态,否则disable状态

var minusStatus = num <= 1 ? 'disabled' : 'normal';

// 购物车数据

var carts = this.data.carts;

carts[index].num = num;

// 按钮可用状态

var minusStatuses = this.data.minusStatuses;

minusStatuses[index] = minusStatus;

// 将数值与状态写回

this.setData({

carts: carts,

minusStatuses: minusStatuses

});

},

效果如图:

1.3 集成LXCheckboxGroup

复制布局文件代码到wxml,这里需要判断一下已选状态,一般购物车勾选状态是记录在网络的。

index值用于传值js,遍历之用。

<!-- 复选框图标 -->

<icon wx:if="{{item.selected}}" type="success_circle" size="20" bindtap="bindCheckbox" data-index="{{index}}"/>

<icon wx:else type="circle" size="20" bindtap="bindCheckbox" data-index="{{index}}"/>

复选框居中

/*复选框样式*/

.carts-list icon { margin-top: 60rpx; margin-right: 20rpx; }

绑定点击复选框事件,对选择状态做反选操作。

bindCheckbox: function(e) {

/*绑定点击事件,将checkbox样式改变为选中与非选中*/

//拿到下标值,以在carts作遍历指示用

var index = parseInt(e.currentTarget.dataset.index);

//原始的icon状态

var selected = this.data.carts[index].selected;

var carts = this.data.carts;

// 对勾选状态取反

carts[index].selected = !selected;

// 写回经点击修改后的数组

this.setData({

carts: carts

});

}

效果图:

1.4 加入全选与立即结算按钮

1.4.1 修改布局文件,实现上述按钮底部对齐,使用flex与固定高度来完成。

减少为3行,看是否还在最底;此外,还要保证悬浮在底部,不被列表项的滚动而滚动。

<view class="carts-footer"> <view bindtap="bindSelectAll"> <icon wx:if="{{selectedAllStatus}}" type="success_circle" size="20"/> <icon wx:else type="circle" size="20" /> <text>全选</text> </view> <view class="button">立即结算</view> </view>

之前用<button>立即结算</button>来实现,发现无论如何都不能实现全选部件与结算按钮分散对齐,不响应如下样式

display: flex;

flex-direction: row;

justify-content: space-between;

样式表

/*底部按钮*/

.carts-footer { width: 100%; height: 80rpx; display: flex; flex-direction: row; justify-content: space-between; }

/*复选框*/

.carts-footer icon { margin-left: 20rpx; }

/*全选字样*/

.carts-footer text { font-size: 30rpx; margin-left: 8rpx; line-height: 10rpx; }

/*立即结算按钮*/

.carts-footer .button { line-height: 80rpx; text-align: center; width:220rpx; height: 80rpx; background-color: #f60; color:white; font-size: 36rpx; border-radius: 0; border: 0; }

1.4.2 全选与全不选事件

实现bindSelectAll事件,改变全选状态

首先定义一个data值,以记录全选状态

selectedAllStatus: false

事件实现:

bindSelectAll: function() {

// 环境中目前已选状态

var selectedAllStatus = this.data.selectedAllStatus;

// 取反操作

selectedAllStatus = !selectedAllStatus;

// 购物车数据,关键是处理selected值

var carts = this.data.carts;

// 遍历

for (var i = 0; i < carts.length; i++) {

carts[i].selected = selectedAllStatus;

}

this.setData({

selectedAllStatus: selectedAllStatus,

carts: carts

});

}

1.4.3 立即结算显示目前所选的cid,以供提交到网络,商品数量应该是包括在cid中的,后端设计应该只关注cid与uid

布局文件也埋一下toast,js只要改变toast的显示与否即可。

<toast hidden="{{toastHidden}}" bindchange="bindToastChange"> {{toastStr}} </toast>

为立即结算绑定事件bindCheckout,弹出cid弹窗

bindCheckout: function() {

// 初始化toastStr字符串

var toastStr = 'cid:';

// 遍历取出已勾选的cid

for (var i = 0; i < this.data.carts.length; i++) {

if (this.data.carts[i].selected) {

toastStr += this.data.carts[i].cid;

toastStr += ' ';

}

}

//存回data

this.setData({

toastHidden: false,

toastStr: toastStr

});

},

bindToastChange: function() { this.setData({

toastHidden: true

});

}

源码下载:关注下方的公众号->回复数字1007

正文完

对小程序开发有趣的朋友关注公众号: huangxiujie85,QQ群: 575136499,微信: small_application,陆续还将推出更多作品。

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言
    友情链接