vue实现简单的购物车小案例

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

最近在写vue的相关项目,所以找一些小例子练习一下,把一个js的购物车改成vue了

css部分是直接引入的插件

效果图如下

<template>
<div class="head">
    <meta charset="UTF-8">
    <title>我的购物车-品优购</title>
    <meta name="description" content="品优购JD.COM-专业的综合网上购物商城,销售家电、数码通讯、电脑、家居百货、服装服饰、母婴、图书、食品等数万个品牌优质商品.便捷、诚信的服务,为您提供愉悦的网上购物体验!" />
    <meta name="Keywords" content="网上购物,网上商城,手机,笔记本,电脑,MP3,CD,VCD,DV,相机,数码,配件,手表,存储卡,品优购" />
<!--    &lt;!&ndash; 引入facicon.ico网页图标 &ndash;&gt;-->
<!--    <link rel="shortcut icon" href="favicon.ico" rel="external nofollow"  type="image/x-icon" />-->
    <!-- 引入css 初始化的css 文件 -->
    <link rel="stylesheet" href="src/assets/carStyle/base.css" rel="external nofollow" >
    <!-- 引入公共样式的css 文件 -->
    <link rel="stylesheet" href="src/assets/carStyle/common.css" rel="external nofollow" >
    <!-- 引入car css -->
    <link rel="stylesheet" href="src/assets/carStyle/car.css" rel="external nofollow" >
</div>
  <div class="body">
    <div class="car-header">
      <div class="w">
        <div class="car-logo">
          <img src="src/assets/images/logo.png" alt=""> <b>购物车</b>
        </div>
      </div>
    </div>
    <div class="c-container">
      <div class="w">
        <div class="cart-filter-bar">
          <em>全部商品</em>
        </div>
        <!-- 购物车主要核心区域 -->
        <div class="cart-warp">
          <!-- 头部全选模块 -->
          <div class="cart-thead">
            <div class="t-checkbox">
              <input type="checkbox" name="" id="" class="checkall"> 全选
            </div>
            <div class="t-goods">商品</div>
            <div class="t-price">单价</div>
            <div class="t-num">数量</div>
            <div class="t-sum">小计</div>
            <div class="t-action">操作</div>
          </div>
          <!-- 商品详细模块 -->
          <div class="cart-item-list" v-for="(good,index) in cartList">

            <div class="cart-item">
              <div class="p-checkbox">
                <input type="checkbox" v-model="good.isSelected" @click="oneSelected(index)">
              </div>
              <div class="p-goods">
                <div class="p-img">
                  <img v-bind:src=good.imgUrl alt="">
                </div>
                <div class="p-msg">{{good.message}}</div>
              </div>
              <div class="p-price">{{good.PriceItem}}</div>
              <div class="p-num">
                <div class="quantity-form">
                  <el-button class="increment" @click="changeDe(index)">-</el-button>
                  <input type="text" class="itxt" v-model=good.ItemNum placeholder="1">
                  <el-button class="increment" @click="changeIn(index)">+</el-button>
                </div>
              </div>
              <div class="p-sum">{{good.PriceSum}}</div>
              <div class="p-action">
                <el-button type="danger" @click="DeleteItem(id)">删除</el-button>
              </div>
            </div>
          </div>

          <!-- 结算模块 -->
          <div class="cart-floatbar">
            <div class="select-all">
              <input type="checkbox" @click="allCheck" v-model="allSelected">全选
            </div>
            <div class="operation">
              <a class="remove-batch" @click="DeleteSelected"> 删除选中的商品</a>
              <a class="clear-all" @click="DeleteAll">清理购物车</a>
            </div>
            <div class="toolbar-right">
              <div class="amount-sum">已经选<em>{{NumSum}}</em>件商品</div>
              <div class="price-sum">总价: <em>{{totalPrice}}</em></div>
              <div class="btn-area">去结算</div>
            </div>
          </div>
        </div>
      </div>

    </div>
  </div>
</template>

<script>
import { defineComponent } from 'vue'
export default defineComponent({
  data(){
    return{
      allSelected:false,
      cartList:[
        {
          imgUrl:'src/assets/upload/p1.jpg',
          message:'【5本26.8元】经典儿童文学彩图青少版八十天环游地球中学生语文教学大纲',
          PriceItem: 12.6,
          PriceSum: 12.6,
          ItemNum: 1,
          isSelected:false
        },
        {
          imgUrl:'src/assets/upload/p2.jpg',
          message:'【2000张贴纸】贴纸书 3-6岁 贴画儿童 贴画书全套12册 贴画 贴纸儿童 汽',
          PriceItem: 24.8,
          PriceSum: 24.8,
          ItemNum: 1,
          isSelected:false
        },
        {
          imgUrl:'src/assets/upload/p3.jpg',
          message:'唐诗三百首+成语故事全2册 一年级课外书 精装注音儿童版 小学生二三年级课外阅读书籍',
          PriceItem: 29.8,
          PriceSum: 29.8,
          ItemNum: 1,
          isSelected:false
        },
      ]
    }
  },
  methods:{
     changeIn(id){
       let n=this.cartList[id].ItemNum;
       // console.log(n);
       this.cartList[id].ItemNum++;
       this.cartList[id].PriceSum = this.cartList[id].ItemNum * this.cartList[id].PriceItem;
     },
    changeDe(id){
       if(this.cartList[id].ItemNum === 0)alert("该商品已经清0!");
       else {
         this.cartList[id].ItemNum--;
         this.cartList[id].PriceSum = this.cartList[id].ItemNum * this.cartList[id].PriceItem;
       }
    },
    DeleteItem(id){
       // console.log(this.$parent);
       // console.log(this.$children);
      this.cartList.splice(id,1);
    },
    allCheck(){
       // console.log(this.allSelected);
     this.cartList.forEach((item)=>{
       // console.log(this.allSelected);
       // console.log(this.cartList);
       item.isSelected=!this.allSelected;
     })
    },
    DeleteSelected(){
       for(let i=0;i<this.cartList.length;i++){
         if(this.cartList[i].isSelected===true){
           this.cartList.splice(i,1);
         }
       }
    },
    DeleteAll(){
      this.cartList.splice(0,this.cartList.length);
    },
    oneSelected(id){
       if(this.cartList[id].isSelected===false)
         this.cartList[id].isSelected=true;
       else
         this.cartList[id].isSelected=false;

      let n=0;
      for(let i=0;i<this.cartList.length;i++){
        if(this.cartList[i].isSelected===true)
          n++;
      }
      if(n===this.cartList.length)this.allSelected=true;
      else this.allSelected=false;
    }
  },
  computed:{
    NumSum() {
      let num=0;
      this.cartList.forEach((item)=>{
        if(item.isSelected===true)
        num++;
      })
      return num;
    },
    totalPrice() {
      let totalp=0;
      this.cartList.forEach((item)=>{
        if(item.isSelected===true)
          totalp += item.PriceSum;
      })
      return totalp;
    },
  }
})

</script>
<style lang="scss" scoped>

</style>

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

(0)

相关推荐

  • 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

  • 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

  • 基于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+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 实现购物车总价计算

    效果如下所示: 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

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

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

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

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

  • vue实现商城购物车功能

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

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

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

随机推荐