uniapp实现购物车功能

uniapp实现购物车功能

周六我看见一个有个公司招聘需要试岗3天,并使用uniapp完成购物车,直播间,地图,首页四个功能方能通过,于是乎,我趁手上没事就打算自己写一遍,虽然我的项目没用到,但是多掌握点总没错。今天就来第一个——购物车
uniapp实现购物车功能_第1张图片

因为没写接口,上面的数据我都是使用的模拟数据搭建而成,主要实现的是它件数的增加减少与支付总价格的逻辑关系,还有左边的全选和全不选。
首先第一步,我们把页面先搭建出来


这是我们页面的结构
其中最开始有一个v-if,大家都知道这是用于条件判断的


			
		空空如也的购物
		去选购
		

这一块就是当我们的购物车是空的时候,页面应该呈现的样子。我也给大家截图出来了
uniapp实现购物车功能_第2张图片
最开始的那个标题栏是因为我觉得没商品的时候黄色和它更搭,有商品的时候红色更美。毕竟我们做前端的,样式还是很重要的。哈哈哈。
结构搭好了,接下来是样式的完成。


基本结构样式写完以后就变成刚刚我们看到的第一张图了,接下来就是对功能的实现了。
先把我们页面需要的假数据写出来

	

接下来就是实现各个功能了,在方法中定义我们需要的
首先页面上有个跳转,在购物车没有东西的时候,我们需要跳转页面去挑选东西

goshopping(){
				uni.navigateTo({
					url:'../contact/contact'
				})
			},

地址根据自己需要的页面地址书写。
接下来就要处理我们每个商品旁边的复选框选中状态与我们全选的关系。
如果所有商品都是选中状态,那我们的全选框也应该被选中。

  • 先来判断单个商品的selected(item)
    1.如果商品都没被选中,则全选为空。
    2.通过循环所有商品,如果全部的flag==true,则表示都被选中,则全选选中,有一个没被选中,全选都应该处于没选中状态。
    代码如下:

    selected(item){
    item.flag=!item.flag
    if(!item.flag){
    this.allchecked=false

    			}else{
    				const a=this.goods.forEach((item)=>{
    					return item.flag===true
    				})
    				if(a){
    					this.allchecked=true
    				}else{
    					this.allchecked=false
    				}
    			}
    		},
    

通过判断单选来实现全选的功能后,接下来我们也要通过全选按钮来控制所有商品的选中状态

  • 再来注册全选按钮事件selectgoods()
    1.点击全选按钮,所有商品全部选中
    2.取消全选选中状态,商品全部处于没选中。

    selectgoods(){
    this.allchecked=!this.allchecked
    if(this.allchecked){
    this.goods.map(item=>{
    this.checked=true
    item.flag=true
    })
    }else{
    this.checked=false
    this.goods.map(item=>{
    item.flag=false
    })
    }
    },

处理完左边的商品选中状态以后,接下来我们要实现对商品的数量的处理,
首先要实现商品数量的增减,一般来说,商品数量是不可能的为0的,为0则表示商品已经不在,所以该商品数量至少为1。
在这里插入图片描述

  • 商品数量的增加add,
    点击+号数量增加一

    add(item){
    let num =item.num
    item.num=num+1
    }

  • 商品数量的减少
    1.点击则数量减少1
    2.数量最少为1,为1后则不能递减

    reduce(item){
    let num=item.num
    if(num>1){
    num-=1
    }else if(num=1){
    uni.showToast({
    title:“该宝贝不能减少了哟~”
    })
    }
    item.num=num
    },

uniapp实现购物车功能_第3张图片
在处理完商品的数量后,本节的重头戏来了,我们还剩下我们的结算金额还没有计算出来,还有购买的总计商品数量也没有显示。
在这里插入图片描述
结算的总金额=(每个商品的单价*每个商品的数量)的总和

  • 先来计算购买商品的数量totalNum()
    1.商品数量初始量为0
    2.从上到下将商品进行遍历
    3.通过判断flag,商品有数量的就把数量num加入总计数,没有的就返回总数量

    totalNum(){
    let totalNum = 0;
    this.goods.map(item => {
    item.flag ? totalNum += item.num : totalNum += 0
    })
    return totalNum
    },

在这儿不得不说我的最爱,三元表达式,真的是太喜欢了。
总数量解决好后,来计算我们的总价格,也就是我们的支付价格。

  • 总价格=商品1的单价_商品1的数量+商品2的单价_商品2的价格+…+商品n的单价*商品n的价格

    totalPrice() {
    		    let totalPrice = 0;
    		    this.goods.map(item => {
    		        item.flag ? totalPrice += item.num * item.price : totalPrice += 0
    		    })
    		    return totalPrice
    		}
    

就这样我们的简单的购物车功能就完成了,是不是很简单呢,里面的逻辑性都不是很强。
最后我再附上全部的完整的代码,个人经验上面代码分散的真的不是很好看。






你可能感兴趣的:(前端,html,小程序,前端,css)