微信小程序,这里实现购物车功能的小demo,有需要此功能的朋友可以参考下。
设计思路:
一、从网络上传入以下Json数据格式的数组 1.购物车id:cid 2.标题title 3.数量num 4.图片地址 5.价格price 6.小计 7.是否选中selected
二、点击复选框toggle操作 如已经选中的,经点击变成未选中,反之而反之 点击依据index作为标识,而不用cid,方便遍历
三、全选操作 首次点击即为全部选中,再次点击为全不选,全选按钮本身也跟随toggle变换
四、点击结算按钮,将已选中的cid数组取出,以供通过网络提交到服务端,这里给个toast作为结果演示。
五、利用stepper作加减运算,同样依据index作为标识,点完写回num值。
六、布局,全选与结算按钮底部对齐,购物车商城自适应高度,类似于Android的weight。
步骤:
初始数据渲染
1.1 布局与样式表
上方是一个商品列表,下方是一个全选按钮与立即结算按钮
商品列表左部为商品缩略图,右上为商品标题,右下为商品价格与数量,其中商品数量使用WXStepper来实现加减操作
js:初始化一个数据源,这往往是从网络获取的,相关接口可参见:https://mp.weixin.qq.com/debug/wxadoc/dev/api/network-request.html
布局文件
样式表
/整体列表/
.carts-list {
display: flex;
flex-direction: column;
padding: 20rpx 40rpx;
}
/每行单元格/
.carts-item {
display: flex;
flex-direction: row;
height:150rpx;
/width属性解决标题文字太短而缩略图偏移/
width:100%;
border-bottom: 1px solid #eee;
padding: 30rpx 0;
}
/左部图片/
.carts-image {
width:150rpx;
height:150rpx;
}
/右部描述/
.carts-text {
width: 100%;
display: flex;
flex-direction: column;
justify-content: space-between;
}
/右上部分标题/
.carts-title {
margin: 10rpx;
font-size: 30rpx;
}
/右下部分价格与数量/
.carts-subtitle {
font-size: 25rpx;
color:darkgray;
padding: 0 20rpx;
display: flex;
flex-direction: row;
justify-content:space-between;
}
/价格/
.carts-price {
color: #f60;
}
1.2 集成WXStepper
1.2.1 复制组件内容
[2016-10-16]
将stepper.wxss的内容复制到cart.wxss中
将stepper.wxml的内容复制到cart.wxml中
与之前的单一组件不同的是:这里要定义数组minusStatuses来与每一个加减按钮相应。当然,合并入carts也是没问题的。
minusStatuses: ['disabled','disabled','normal','disabled']
原来的静态字符WXStepper换成以下的代码
js代码bindMinus、bindPlus分别改造为如下:
效果如图:
[2016-10-17]
修正手工改动数量保存到数组
1.3 集成LXCheckBoxGroup
复制布局文件代码到wxml,这里需要判断一下已选状态,一般购物车勾选状态是记录在网络的。
index值用于传值js,遍历之用。
<div class="jb51code">
<pre class="brush:xml;">
<icon wx:if="{{item.selected}}" type="success_circle" size="20" bindtap="bindCheck<a href="https://www.jb51.cc/tag/Box/" target="_blank" class="keywords">Box</a>" data-index="{{index}}"/>
<icon wx:else type="circle" size="20" bindtap="bindCheck<a href="https://www.jb51.cc/tag/Box/" target="_blank" class="keywords">Box</a>" data-index="{{index}}"/>