当前位置:
首页 > temp > JavaScript教程 >
-
第八十四篇:Vue购物车(五) 商品数量的增减
好家伙,
1.商品数量的增减
我们把商品的数量增减独立出来,写成一个独立的组件Counter
<template>
<div class="number-container d-flex justify-content-center align-items-center">
<!-- 减 1 的按钮 -->
<button type="button" class="btn btn-light btn-sm">-</button>
<!-- 购买的数量 -->
<span class="number-box">1</span>
<!-- 加 1 的按钮 -->
<button type="button" class="btn btn-light btn-sm">+</button>
</div>
</template>
<script>
export default {}
</script>
<style lang="less" scoped>
.number-box {
min-width: 30px;
text-align: center;
margin: 0 5px;
font-size: 12px;
}
.btn-sm {
width: 30px;
}
</style>
它长这个样子:
我们的组件关系为:
App.vue(父组件)==>Goods.vue(商品的渲染)==>Counter.vue(商品的增减)
嵌套关系清楚了,那么传值的步骤也清楚了
我们先在Counter添加一个进行商品数量更改的方法,随后,想办法把这个值传回到App.vue
这里的传值就是孙=>子=>父,看着都很麻烦,所以我们这里用到的传值方案是eventBus
当然了,传值时不仅仅是商品的数量,还有商品的id
Counter.vue中的props定义
props:{
isfull:{
type:Boolean,
default:true
},
amount:{
type:Number,
default:0
}
},
Goods.vue中组件调用时的传值
<Counter :num="count" :id="id"></Counter>
在Counter.vue中为button绑定点击触发add方法
<button type="button" class="btn btn-light btn-sm"
@click="add">+</button>
方法add的定义:
methods:{
add(){
//要发送给App的数据格式为{ id,value }
//其中,id是商品的id;value是商品最新的购买数量
const obj ={ id:this.id,value:this.num+1 }
//通过EventBus把obj对象,发送给App.vue组件
console.log(obj)
bus.$emit('share',obj)
//把obj对象传到App.vue中
}
}
对了,不要忘记导入eventBus.js
import bus from '../eventBus.js'
在eventBus.js中(与App.vue平级)
import Vue from 'vue'
export default new Vue()
回到App.vue中,
添加created钩子的定义
created(){
bus.$on('share',val=>{
if(item.id===val.id){
item.goods_count=val.value
return true
}
})
},
商品数量增减的功能就实现了,nice
出处:https://www.cnblogs.com/FatTiger4399/p/16293885.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数