首页 > 其他分享 >Vue购物车实例练习

Vue购物车实例练习

时间:2023-05-22 12:25:39浏览次数:47  
标签:count index Vue name price list 购物车 实例 null

效果图

功能介绍
  1. 金额 = 单价 * 数量金额会自动根据数量的变化进行变化,我们可以点击按钮增加或减少商品的数量。
  2. 合计金额:只有在序号列号勾选上才会被计入总金额中,金额总数会根据用户的操作自动更新数据。
  3. 删除:如图我们勾选了第2个商品,当我们点击删除时,只会删除被选中的产品。
  4. 全选:点击1次全选会选中所有商品,第2次点击时就会取消已经选中的商品。
  5. 添加:用户可以自己添加商品、商品的单价、数量

代码

表头
<!-- 表头 -->
<tr style="font-weight: 800;">
  <td>序号</td>
  <td>商品</td>
  <td>单价(元)</td>
  <td>数量</td>
  <td>金额(元)</td>
</tr> 
商品表
  1. 点击增加或减少会调用方法函数,改变商品的数量
  2. 商品数量采用input,使用v-model实时变化商品的数量,用户可以直接输入商品数量
  3. 金额会根据商品单价和数量自动进行变化
<!-- 商品表 -->
<tr v-for="(value,index) in list">
  <td><input type="checkbox" v-model="value.checked"></td>
  <td>
    <img v-bind:src="value.src" alt="图片" id="commodityImg">
    <span>{{value.name}}</span>
    <span style="font-size: 0.8em; color: #919191;">{{value.introduce}}</span>  
  </td>
  <td style="color: #e00000;">¥{{ value.price }}</td>
  <td style="padding: 0 !important;">
    <button @click="reduce(index)">-</button>
    <input type="text" v-model="value.count">
    <button @click="add(index)">+</button>
  </td>
  
  <!-- 金额会根据商品单价和数量自动进行变化 -->  
  <td style="color: #e00000;font-weight: 800;">¥{{value.price*value.count}}</td>
</tr>
添加商品
<!-- 添加商品 -->
<tr id="add">
  <td></td>
  <td><input type="text" v-model="push.name" placeholder="商品"></td>
  <td><input type="text" v-model="push.price" placeholder="价格"></td>
  <td><input type="text" v-model="push.count" placeholder="数量"></td>
  <td><button id="push" @click="pushValue">添加</button></td>
</tr>
全选、删除、合计等操作
<!-- 全选、删除、合计等操作 -->
<tr>
  <td colspan="2">
    <div @click="selectAll" ><input type="checkbox" v-model="selectAllValue">全选</div>
    <div @click="selectDel" >&nbsp;&nbsp;删除</div>
  </td>
  <td colspan="3">
    合计:<p style="color: #e00000;font-weight: 800;padding: 0.6em 0em; display: contents;">¥{{priceSums}}</p></td> 
</tr>
数据源
data(){
    return{
      selectAllValue:1,
      priceSums:0,
      push:{
        name:null,
        price:null,
        count:null,
        prices:null,
      },
      list:[{
          checked:'false',
          name:'微信公众号',
          src:'https://mp.weixin.qq.com/mp/qrcode?scene=10000004&size=102&__biz=MzkzMjE5OTMwOA==&mid=2247487964&idx=1&sn=f7474b00c99bb7017530e4fbffd0c62d&send_time=',
          introduce:'扫码关注,和群友们一起交流学习',
          price:9999,
          count:2,
          prices:null,
      },
      {
          checked:'false',
          name:'QQ交流群',
          src:'',
          introduce:'',
          price:6666,
          count:1,
          prices:null,
      },
      { 
          checked:'false',
          name:'MacBookPro',
          src:'https://img10.360buyimg.com/n2/jfs/t1/203950/20/28591/140129/637ca996E10cf6f5c/bb31749afd714364.jpg',
          introduce:'',
          price:21488,
          count:1,
          prices:null,
      }],    
    }
  },
computed计算属性,根据金额列的变化而变化

计算属性是基于它们的响应式依赖进行缓存的,只在相关响应式依赖发生改变时它们才会重新求值。

computed:{
    // 计算总和
    priceSums:function(){
      var sum = 0;
      for(var i = 0; i != this.list.length; i++){
        if(this.list[i].checked == true){
          sum = sum + this.list[i].price * this.list[i].count;
        }   
      }
      return sum;
    }
  },
利用methods定义一些方法
methods:{
    //减少物品个数
    reduce:function(index){
      this.list[index].count = this.list[index].count - 1;
      if(this.list[index].count == -1){
        this.list.splice(index,1)
      }
    },
    
    // 增加物品个数
    add:function(index){
      this.list[index].count = this.list[index].count + 1;
    },
    
    // 添加新元素在购物车中
    pushValue:function(){    
      console.log(this.push.name)
      if(this.push.name == undefined) return 0;  
      for(var i=0; i<this.lsist.length; i++){
        if(this.list[i].name == this.push.name){
          alert("你已勾选此产品");
          return 0;
        }
      }
      this.list.push(this.push);
      this.push = {name:'', price:null, count:null};
    },
    
    // 选中所有
    selectAll:function(){
      for(var i=0,j=0; i<this.list.length; i++){
        if(this.list[i].checked == true){
          if(i==j){
            for(var k=0; k<this.list.length; k++){
              this.list[k].checked = false;
            }
            this.selectAllValue = false;
            return 0;    
          }
          j++;
        }
        this.list[i].checked = true;
      }
      this.selectAllValue = true;
    },
    
    // 删除选中
    selectDel:function(){
      if(confirm("你确认要删除吗?","提示框 ")){
        for(var i=0; i<this.list.length; i++){
          if(this.list[i].checked == true){
            this.list.splice(i,1);
          }
        }
      }
    }
  }

公众号:小知识酷,回复“VueShoppingCart1”获取完整源码

标签:count,index,Vue,name,price,list,购物车,实例,null
From: https://www.cnblogs.com/MrFlySand/p/17420265.html

相关文章

  • 动态规划 实例
    算法-动态规划动态规划实例一、数字三角形(树形动规)1、简单的递归2、记忆递归型的动态规划2、递推型动态规划总结:二、石子游戏LeetCode=i=lmaxr{f[l][i]+sum(l,i)}动态规划实例一、数字三角形(树形动规)7 38 810 2744 4526......
  • VUE npm run serve 提示error Mixed spaces and tabs no-mixed-spaces-and-tabs 解决
    解析:看这个错误提示意思就是“不允许代码中出现空格和tab键混合的情况”大多数代码约定要求使用空格或tab进行缩进,禁止使用空格和tab混合缩进。因此,一行代码同时混有tab缩进和空格缩进,通常是错误的。解决办法:原因找到了,解决办法就是找到spaces和tabs混合的地方,然后统一即可!......
  • vue项目结合vant,实现上拉加载更多,下拉刷新
    上拉加载思路:引入vant组件上拉list后端数据做了分页处理,获取接口数据,渲染到页面上,(此处只会显示一页的数据)设置属性去实现效果,loading,finished为vant组件中提供的每次滚动到底部后把页面数+1,发送一次请求获取新分页数据.获取完数据,将新获取的数据跟上一页获取的数据做......
  • Matlab符号计算(实例)
    %%1.数值常量转换为符号变量%%2.符号表达式的创建%%3.符号表达式中符号自变量的确定%%4.符号对象和数值对象的转换%%5.符号数值的精度控制%%6.合并同类项%%7.因式分解%%8.分子多项式和分母多项式的提取%%9.符号表达式的展开%%10.......
  • java基于的springboot+vue4S店车辆管理系统,车辆销售管理系统,附源码+数据库+lw文档+PPT
    1、项目介绍首先介绍了4S店车辆管理的技术发展背景与发展现状,然后遵循软件常规开发流程,首先针对系统选取适用的语言和开发平台,根据需求分析制定模块并设计数据库结构,再根据系统总体功能模块的设计绘制系统的功能模块图,流程图以及E-R图。然后,设计框架并根据设计的框架编写代码以实......
  • React 入门实例教程
    现在最热门的前端框架,毫无疑问是 React 。上周,基于React的 ReactNative 发布,结果一天之内,就获得了5000颗星,受瞩目程度可见一斑。React起源于Facebook的内部项目,因为该公司对市场上所有 JavaScriptMVC框架,都不满意,就决定自己写一套,用来架设 Instagram 的网站。做出......
  • Asp.net MVC 3实例学习之ExtShop(六)——登录对话框
         登录对话框将使用jquery提供的对话框,所以不需要添加其它js文件。首先要为登录对话框添加一个表单模型。在Models目录下创建一个“AccountModels”类文件,然后添加一个Logon类,代码如下:1     public class LogOnModel2     {3      ......
  • vue实现卡片滚动效果
    vue实现卡片滚动左右切换效果HTML://最外层盒子<divclass="box_1"> //内层盒子 <divclass="box_2" :style="{transform:'translateX'+'('+currentOffset+'px'+')',}"> //中间放需要展示的div,样式......
  • java基于springboot+vue的土特产在线销售平台、特产在线销售商城,附源码+数据库+lw文档
    1、项目介绍考虑到实际生活中在藏区特产销售管理方面的需要以及对该系统认真的分析,将系统权限按管理员和用户这两类涉及用户划分。(1)管理员功能需求管理员登陆后,主要模块包括首页、个人中心、用户管理、特产信息管理、特产分类管理、特产分类管理、特产评分管理、系统管理、订单......
  • Vue进阶(九十八):Vue.set() 和 this.$set()
    (文章目录)一、应用场景有时候我们会看到如下代码:在我们使用vue进行开发的过程中,可能会遇到这样一种情况:当创建vue实例后,再次给对象赋值时,发现数据并不会自动更新到视图上去;当我们去阅读vue文档的时候,会发现有这么一句话:如果在实例创建之后添加新的属性到实例上,它不会触发视图......