欢迎来到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  

效果图实现以下功能一、 点击分类项,切换右边的食品,并高亮自身这个实现比较简单,给一个states数组,用于记录每一项分类的状态,点击设为true,wxml渲染时三目运算判断即可。categoryStates = categoryStates.map ...

 

 

 

效果图

黄秀杰教程--灵犀外卖选购页实现切换分类与数量加减

实现以下功能

一、 点击分类项,切换右边的食品,并高亮自身 
这个实现比较简单,给一个states数组,用于记录每一项分类的状态,点击设为true,wxml渲染时三目运算判断即可。

 

categoryStates = categoryStates.map(function(item, i){

if(index == i){

item =true;

}else{

item =false;

}

return item;

});

相应的wxml文件,class="{{categoryStates[index] ? 'category-item-active' : ''}}"

二、 加减按钮  初始只有一个加号  点击加号后,相应商品数量+1,并出现减号  减至0时,减号消失,连同数量值

设计数组结构

 

cartData:{},它的键是Food表的objectId,值是数量。

以下是js代码实现

add:function(e){

// 所点商品id

var foodId = e.currentTarget.dataset.foodId;

console.log(foodId);

// 读取目前购物车数据

var cartData = that.data.cartData;

// 获取当前商品数量

var foodCount = cartData[foodId]? cartData[foodId]:0;

// 自增1后存回

cartData[foodId]=++foodCount;

// 设值到data数据中

that.setData({

cartData: cartData

});

}

在wxml文件中绑定数据如下

 

<viewclass="stepper">

<!-- 减号 -->

<viewclass="symbol subtract"wx:if="{{cartData[item.objectId]}}">-</view>

<!-- 数量 -->

<viewclass="value">{{cartData[item.objectId]}}</view>

<!-- 加号 -->

<viewclass="symbol add"bindtap="add"data-food-id="{{item.objectId}}">+</view>

</view>

上述代码中,通过wx:if判断当前商品的数量是否存在,无则不显示减号按钮;而在加号按钮旁要显示的数量就是{{cartData[item.objectId]}};点击事件传递的foodId就是{{item.objectId}}

减法按钮类似

 

subtract:function(e){

// 所点商品id

var foodId = e.currentTarget.dataset.foodId;

// 读取目前购物车数据

var cartData = that.data.cartData;

// 获取当前商品数量

var foodCount = cartData[foodId];

// 自减1

--foodCount;

// 减到零了就直接移除

if(foodCount ==0){

delete cartData[foodId]

}else{

cartData[foodId]= foodCount;

}

// 设值到data数据中

that.setData({

cartData: cartData

});