vue实现购物车功能(亲测可用)

本文实例为大家分享了vue实现购物车功能的具体代码,供大家参考,具体内容如下

如图,需要有加入购物车的标识

思路如下:点击购物车按钮时将商品的id,title,imgUrl(海报图),flag(标识符,flag非常重要,为以后复选框判断是否选中做参考)变成一个数组形式,cart,传入vuex

<template>
    <div>
  <van-goods-action>
    <van-goods-action-icon icon="chat-o" text="客服" @click="onClickIcon" />
    <van-goods-action-icon icon="cart-o" text="购物车" @click="onClickIcon" />
    <van-goods-action-button
      type="warning"
      text="加入购物车"
      @click="onClickButton"
    />
    <van-goods-action-button
      type="danger"
      text="立即购买"
      @click="onClickButton"
    />
  </van-goods-action>
    </div>
</template>

<script>
  import { Toast } from 'vant';
  import { GoodsAction, GoodsActionIcon, GoodsActionButton } from 'vant';
  export default {
    name: 'tabs',
    data(){
      return{

      }
    },
    props:{
      id:String,
      current:String,
      title:String,
      imgUrl:String
    },
    components:{
      [Toast.name]: Toast,
      [GoodsAction.name]: GoodsAction,
      [GoodsActionIcon.name]: GoodsActionIcon,
      [GoodsActionButton.name]: GoodsActionButton
    },
     methods: {
        onClickIcon() {
          Toast('点击图标');
        },
        onClickButton() {
          var cart={id:this.id,current:this.current,num:1,title:this.title,imgUrl:this.imgUrl,flag:true}
          this.$store.commit('addCart',cart)
          Toast('已加入购物车');
        },
      },
    }
</script>

<style>
</style>

2.vuex如下

import Vue from 'vue'
import Vuex from 'vuex'
import mutations from './mutations.js'
Vue.use(Vuex)
export default new Vuex.Store({
  state: {
    cart:[],
    money:0,
    allchecked:true
  },
  mutations,
})
export default{、
//判断是否已经加入过购物车,如果加入过,则该产品数量加一,若没有加入过,将产品加入cart中
  addCart(state,data){
    for(var i=0;i<state.cart.length;i++){
      if(state.cart[i].id==data.id){
        state.cart[i].num+=data.num
        return
      }
    }
    state.cart.push(data)
  },
  //该函数为数字+1
  addCartNum(state,index){
    state.cart[index].num++
  },
    //该函数为数字-1
  jianCartNum(state,index){
    if(state.cart[index].num==1){return;}
    state.cart[index].num--
  },
}

3.购物车

思路如下:若没有产品则显示无产品,若有产品在购物车里,则可进行增删加减

<template>
  <div class="bg">
    <div class="bgCart" v-if="isGood">
      <div class="cartAd">
        <h3>
          购物车
        </h3>
        <div v-if="select">
          <div class="admin" @click="onAdmin">管理</div>
        </div>
        <div v-if="!select">
          <div class="admin" @click="onOk">完成</div>
        </div>
      </div>
      <van-checkbox-group v-model="result" ref="checkboxGroup">
        <div class="cart" v-for="(item,index) in cartList" :key="index">
          <van-checkbox :name="item.id" class="checkbox" checked-color="red" v-model="item.flag" @click="chooseChange(item.id, item)">
          </van-checkbox>
          <div class="box">
            <img class="img" :src="baseUrl+item.imgUrl" />
            <div class="wraper">
              <div class="title">{{item.title}}</div>
              <div class="container">
                <div class="money">¥{{item.current}}</div>
                <div>
                  <span class="jian" @click="jian(index)">
                    <span class="jianAdj"> -</span>
                  </span>
                  <span>{{item.num}}</span>
                  <span class="jia" @click="add(index)">
                    <span class="jiaAdj"> +</span>
                  </span>
                </div>
              </div>
            </div>
          </div>
        </div>
      </van-checkbox-group>
      <div class="order" v-if="select">

        <van-submit-bar :price="getAll" button-text="提交订单">
          <van-checkbox v-model="allchecked" checked-color="red" @click="allOrder">全选/取消</van-checkbox>
        </van-submit-bar>
      </div>
      <div class="order" v-if="!select">
        <van-submit-bar :price="getAll" button-text="删除" @submit="del">
          <van-checkbox v-model="allchecked" checked-color="red" @click="allOrder">全选/取消</van-checkbox>
        </van-submit-bar>
      </div>
 </div>
 <div v-if="!isGood" class="noGood">
  <h3>
    购物车
  </h3>
  <img src="../../../static/img/cart.jpg"/>
   <span class="add">
      您还没有添加任何产品哦
   </span>
   <van-button round  type="danger">去逛逛</van-button>
 </div>
      <bottom></bottom>
  </div>
</template>

<script>
  import {
    Checkbox,
    CheckboxGroup
  } from 'vant';
  import {
    SubmitBar
  } from 'vant';
  import {
    Button
  } from 'vant';
  export default {
    name: 'cart',
    data() {
      return {
        result: [],
        cartList: [],
        select: true,
        money: 0,
        results: [],
        baseUrl: this.common.baseUrl,
        allchecked: this.$store.state.allchecked,
        isGood:true
      }
    },
    components: {
      [SubmitBar.name]: SubmitBar,
      [Button.name]: Button,
      [Checkbox.name]: Checkbox,
      [CheckboxGroup.name]: CheckboxGroup,
      bottom: () => import('./components/bottom.vue')
    },
    computed: {
      getAll() {
        var money = 0
        this.$store.state.cart.forEach(item => {
          if (item.flag) {
            money += (item.num * item.current) * 100
          }
        })
        return money
      }
    },
    methods: {
      //选择单个复选框(非常重要)
     //由于我进来是使复选框全选,则在第一次点击的时候使得flag=false
      chooseChange(i, item) {
        if (this.result.indexOf(i) > -1) {
          var arrs = this.result.filter(function(item) {
            return item != i;
          });
          this.result = arrs;
          item.flag = false;
        } else {
          this.result.push(i);
          item.flag = true;
        }
        //判断单个和全部,若单个全选,则this.$store.state.allchecked为true
        if (this.result.length < this.$store.state.cart.length) {
          this.$store.state.allchecked = false;
          this.allchecked = this.$store.state.allchecked;
        } else {
          this.$store.state.allchecked = true;
          this.allchecked = this.$store.state.allchecked;
        }
      },
      //全选状态
      allOrder() {
        //如果选择状态为选中的时候,设置this.$store.state.allchecked=false变成未选中
        if (this.$store.state.allchecked) {
          this.$store.state.cart.forEach(item => {
            item.flag = false;
          })
          this.result = [];
          this.$store.state.allchecked = false;
          this.allchecked = this.$store.state.allchecked;
        } else {
          this.$store.state.cart.forEach(item => {
            item.flag = true;
            if (this.result.indexOf(item.id) < 0) {
              this.result.push(item.id);
            }
          })
          this.$store.state.allchecked = true;
          this.allchecked = this.$store.state.allchecked;
        }
      },
      //数字+
      add(index) {
        this.$store.commit('addCartNum', index)

      },
      //数字减
      jian(index) {
        this.$store.commit('jianCartNum', index)
      },
      //点击管理
      onAdmin() {
        this.select = false
      },
      //点击完成
      onOk() {
        this.select = true
        if(this.result.length==0){
          console.log(1)
          this.isGood=false
        }else{
           console.log(this.result)
        }
      },
      //删除
      del() {
        if (this.result.length == this.$store.state.cart.length) {
          this.$store.state.cart.splice(0, this.result.length)
          this.result.splice(0, this.result.length)
        } else {
          this.$store.state.cart.forEach(item => {
            if (item.flag) {
              this.$store.state.cart.splice(item, 1)
              this.result.splice(item.id, 1)
            }
          })
        }
      }
    },
    created() {
      this.cartList = this.$store.state.cart
      if (this.$store.state.allchecked) {
        for (var i = 0; i < this.$store.state.cart.length; i++) {
          this.result.push(this.$store.state.cart[i].id)
        }
      }
      if(this.result.length==0){
        this.isGood=false
      }
    }
  }
</script>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • vuejs手把手教你写一个完整的购物车实例代码

    由于我们公司是主营业务是海淘,所以每个项目都是类似淘宝天猫之类的商城,那么购物车就是一个重点开发功能模块.介于之前我都是用jq来写购物车的,这次就用vuejs来写一个购物车.下面我就从全选,数量控制器,运费,商品金额计算等方法来演示一下一个能用在实际场景的购物车是怎么做出来的以及记录一下这次用vuejs踩过的坑. 1.一层数据结构-全选 下面这段代码和vuejs官网里面checkbox绑定很像.不明白的可以直接上vuejs官网看看. <!DOCTYPE html> <html lang=

  • Vue实现购物车功能

    效果图: 代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.0.2/css/bootstrap.min.css" rel="external nofollow" /> &l

  • vuex实现的简单购物车功能示例

    本文实例讲述了vuex实现的简单购物车功能.分享给大家供大家参考,具体如下: 购物车组件 <template> <div> <h1>vuex-shopCart</h1> <div class="shop-listbox"> <shop-list/> </div> <h2>已选商品</h2> <div class="shop-cartbox"> &l

  • Vue实现购物车详情页面的方法

    上次我们为商品分类菜单添加了显示购物数量,这篇我们继续推进项目,来实现购物车的详情页面,在开始之前我们先看它在页面中的样子: 如上所示,此页面包含了购物列表,而它由商品名称,单价,增减商品功能构成,增减商品功能我们在商品列表中实现过,那么我们现在可以进行复用. 搭出购物车结构 我们将购物车底部构建出来, <templete> <div class="shopcart" :class="{'highligh':totalCount>0}">

  • vue实现购物车抛物线小球动画效果的方法详解

    本文实例讲述了vue实现购物车抛物线小球动画效果的方法.分享给大家供大家参考,具体如下: 先上最终效果图,在商品页面和商品详情页面点击加号添加商品时都可以看到小球抛物线落入购物车的动画效果 此文章只写了商品页面购物小球的实现,商品详情页原理类似 实现步骤: 1. 需要三个组件,最下方包含蓝色购物车的[购物车]组件shopCart.vue(子组件),每个[加减号]组成的购物小球组件cartControl.vue(子组件),和包含每个商品信息的goods组件goods.vue(父组件) 2. 原理,

  • vue+vant-UI框架实现购物车的复选框全选和反选功能

    购物车页面的设计图 商品的列表 代码: <ul v-if="shoppingListData.rows.length"> <li v-for="(item,index) in shoppingListData.rows" :key="index" > <van-checkbox :value="item.goods_id" v-model="item.isChecked" ch

  • vue实现购物车小案例

    本文实例为大家分享了vue实现购物车小案例的具体代码,供大家参考,具体内容如下 最终效果 HTML部分: <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>shopcar.html</title> <script src="https://cdn.jsdelivr.net/npm/vue&q

  • 基于Vuejs实现购物车功能

    本文实例为大家分享了Vuejs购物车实现代码,供大家参考,具体内容如下 html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>我的vue购物车</title> <link rel="stylesheet" href="css/bootstrap.min.css&q

  • vue实现商城购物车功能

    本文实例为大家分享了vue实现商城购物车功能的具体代码,供大家参考,具体内容如下 首先,先上最终的效果图 效果并不是很好看,但是这不是重点. 首先,我们先看下布局: <template> <div class="shopcar" id="demo04"> <div class="header-title"> <h3>购物车</h3> </div> <div class=

  • vue 实现购物车总价计算

    效果如下所示: js <script type="text/javascript"> window.οnlοad=function () { var vm = new Vue({ el:'#huo', data:{ myList:[ { number:0, price:23 }, { number:0, price:14.5 }, { number:1, price:8 }, { number:0, price:20 } ], total:0, //总价 bestValue

随机推荐