好家伙,

1.商品数量的增减

我们把商品的数量增减独立出来,写成一个独立的组件Counter

  1. <template>
  2. <div class="number-container d-flex justify-content-center align-items-center">
  3. <!-- 减 1 的按钮 -->
  4. <button type="button" class="btn btn-light btn-sm">-</button>
  5. <!-- 购买的数量 -->
  6. <span class="number-box">1</span>
  7. <!-- 加 1 的按钮 -->
  8. <button type="button" class="btn btn-light btn-sm">+</button>
  9. </div>
  10. </template>
  11.  
  12. <script>
  13. export default {}
  14. </script>
  15.  
  16. <style lang="less" scoped>
  17. .number-box {
  18. min-width: 30px;
  19. text-align: center;
  20. margin: 0 5px;
  21. font-size: 12px;
  22. }
  23.  
  24. .btn-sm {
  25. width: 30px;
  26. }
  27. </style>

它长这个样子:

 

 

我们的组件关系为:

App.vue(父组件)==>Goods.vue(商品的渲染)==>Counter.vue(商品的增减)

 

嵌套关系清楚了,那么传值的步骤也清楚了

我们先在Counter添加一个进行商品数量更改的方法,随后,想办法把这个值传回到App.vue

这里的传值就是孙=>子=>父,看着都很麻烦,所以我们这里用到的传值方案是eventBus

当然了,传值时不仅仅是商品的数量,还有商品的id

Counter.vue中的props定义

  1. props:{
  2. isfull:{
  3. type:Boolean,
  4. default:true
  5. },
  6. amount:{
  7. type:Number,
  8. default:0
  9. }
  10. },

Goods.vue中组件调用时的传值

  1. <Counter :num="count" :id="id"></Counter>

在Counter.vue中为button绑定点击触发add方法

  1. <button type="button" class="btn btn-light btn-sm"
  2. @click="add">+</button>

方法add的定义:

  1. methods:{
  2. add(){
  3. //要发送给App的数据格式为{ id,value }
  4. //其中,id是商品的id;value是商品最新的购买数量
  5. const obj ={ id:this.id,value:this.num+1 }
  6. //通过EventBus把obj对象,发送给App.vue组件
  7. console.log(obj)
  8. bus.$emit('share',obj)
        //把obj对象传到App.vue中
  9. }
  10. }

对了,不要忘记导入eventBus.js

  1. import bus from '../eventBus.js'

在eventBus.js中(与App.vue平级)

  1. import Vue from 'vue'
  2.  
  3. export default new Vue()

回到App.vue中,

添加created钩子的定义

  1. created(){
  2.  
  3. bus.$on('share',val=>{
  4. if(item.id===val.id){
  5. item.goods_count=val.value
  6. return true
  7. }
  8. })
  9. },

商品数量增减的功能就实现了,nice

第八十四篇:Vue购物车(五) 商品数量的增减的更多相关文章

  1. 《手把手教你》系列基础篇(八十四)-java+ selenium自动化测试-框架设计基础-TestNG日志-上篇(详解教程)

    1.简介 TestNG还为我们提供了测试的记录功能-日志.例如,在运行测试用例期间,用户希望在控制台中记录一些信息.信息可以是任何细节取决于目的.牢记我们正在使用Selenium进行测试,我们需要有助 ...

  2. Spring Cloud第十四篇 | Api网关Zuul

    ​ 本文是Spring Cloud专栏的第十四篇文章,了解前十三篇文章内容有助于更好的理解本文: Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览 Spring C ...

  3. “全栈2019”Java第八十四章:接口中嵌套接口详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  4. Egret入门学习日记 --- 第十四篇(书中 5.4~5.6节 内容)

    第十四篇(书中 5.4~5.6节 内容) 书中内容: 总结 5.4节 内容重点: 1.如何编写自定义组件? 跟着做: 重点1:如何编写自定义组件? 文中提到了重要的两点. 好,我们来试试看. 第一步, ...

  5. 解剖SQLSERVER 第十四篇 Vardecimals 存储格式揭秘(译)

    解剖SQLSERVER 第十四篇    Vardecimals 存储格式揭秘(译) http://improve.dk/how-are-vardecimals-stored/ 在这篇文章,我将深入研究 ...

  6. 第十四篇 Integration Services:项目转换

    本篇文章是Integration Services系列的第十四篇,详细内容请参考原文. 简介在前一篇,我们查看了SSIS变量,变量配置和表达式管理动态值.在这一篇,我们使用SQL Server数据商业 ...

  7. Python之路【第十四篇】:AngularJS --暂无内容-待更新

    Python之路[第十四篇]:AngularJS --暂无内容-待更新

  8. 第三百八十四节,Django+Xadmin打造上线标准的在线教育平台—路由映射与静态文件配置以及会员注册

    第三百八十四节,Django+Xadmin打造上线标准的在线教育平台—路由映射与静态文件配置以及会员注册 基于类的路由映射 from django.conf.urls import url, incl ...

  9. 【译】第十四篇 Integration Services:项目转换

    本篇文章是Integration Services系列的第十四篇,详细内容请参考原文. 简介在前一篇,我们查看了SSIS变量,变量配置和表达式管理动态值.在这一篇,我们使用SQL Server数据商业 ...

随机推荐

  1. 【Redis】Redis Cluster-集群故障转移

    集群故障转移 节点下线 在集群定时任务clusterCron中,会遍历集群中的节点,对每个节点进行检查,判断节点是否下线.与节点下线相关的状态有两个,分别为CLUSTER_NODE_PFAIL和CLU ...

  2. Mybatis架构原理(二)-二级缓存源码剖析

    Mybatis架构原理(二)-二级缓存源码剖析 二级缓存构建在一级缓存之上,在收到查询请求时,Mybatis首先会查询二级缓存,若二级缓存没有命中,再去查询一级缓存,一级缓存没有,在查询数据库; 二级 ...

  3. UiPath鼠标操作元素的介绍和使用

    一.鼠标(mouse)操作的介绍 模拟用户使用鼠标操作的一种行为,例如单击,双击,悬浮.根据作用对象的不同我们可以分为对元素的操作.对文本的操作和对图像的操作 二.鼠标对元素的操作在UiPath中的使 ...

  4. Python自动化办公:27行代码实现将多个Excel表格内容批量汇总合并到一个表格

    序言 (https://jq.qq.com/?_wv=1027&k=GmeRhIX0) 老板最近越来越过分了,快下班了发给我几百个表格让我把内容合并到一个表格内去.还好我会Python,分分钟 ...

  5. EasyExcel导出创建Excel下拉框

    话不多说,上才艺. 下面代码粘贴即用 /** * * 导出表格带下拉框 */ @GetMapping("exportBox") public void export(HttpSer ...

  6. 数据结构-二叉树(Binary Tree)

    1.二叉树(Binary Tree) 是n(n>=0)个结点的有限集合,该集合或者为空集(空二叉树),或者由一个根节点和两棵互不相交的,分别称为根节点的左子树和右子树的二叉树组成.  2.特数二 ...

  7. 【cartogarpher_ros】二: 官方Demo的介绍与演示

    上一节我们介绍了在linux中快速安装集成ros环境的cartographer. 本节我们会来跑一些官方demo,用于测试cartographer是否正确安装,顺便看看cartographer的建图与 ...

  8. 异常概念&异常体系和异常分类

    异常概念 异常:指的是程序在执行过程中,出现的非正常的情况,最终会导致JVM的非正常停止. 在Java等面向对象的编程语言中,异常本身是一个类,产生异常就是创建异常对象并抛出了一个异常对象.Java处 ...

  9. Map集合概述和Map常用子类

    概述java.util.Map接口 Map<K,V> 有两个泛型 类型参数:K - 此映射所维护的键的类型V - 映射值的类型 特点:1.Map集合是双列集合,一个元素包含两个值,一个是k ...

  10. C++系统函数

    C++语言预先编写了很多常用函数提供给广大程序员使用,这些函数被统称为系统函数.C++语言全盘继承了C语言的标准C库,另外又增加了一些新的库(更多的是系统类库),这些新库被统称为C++标准库. 一.C ...