vue外卖十七:商家详情-cartControl组件:购物车加减商品组件及功能

本文主要是介绍vue外卖十七:商家详情-cartControl组件:购物车加减商品组件及功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、基础页面

1.创建静态页面+接收props传值src/components/CartControl/cartControl.vue

<template>  <div class="cartcontrol"><div class="iconfont icon-remove_circle_outline"></div><div class="cart-count">1</div><div class="iconfont icon-add_circle"></div></div>
</template><script>export default{props:{food:Object}}
</script><style lang="stylus" rel="stylesheet/stylus">@import "../../common/stylus/mixins.styl".cartcontrolfont-size: 0.cart-decreasedisplay: inline-blockpadding: 6pxline-height: 24pxfont-size: 24pxcolor: rgb(0, 160, 220).icon-remove_circle_outlinedisplay: inline-blockpadding 6pxline-height 24pxfont-size 24pxcolor $green&.move-enter-active, &.move-leave-activetransition all .3s&.move-enter, &.move-leave-toopacity 0transform translateX(15px) rotate(180deg).cart-countdisplay: inline-blockvertical-align: topwidth: 12pxpadding-top: 6pxline-height: 24pxtext-align: centerfont-size: 10pxcolor: rgb(147, 153, 159).icon-add_circledisplay: inline-blockpadding: 6pxline-height: 24pxfont-size: 24pxcolor $green
</style>

2.使用购物车组件+传food到子组件

<div class="cartcontrol-wrapper">
<!--3】使用并传food到cartcontrol子组件
引号内,是当前页面的值;冒号后,是子组件接收的名--><CartControl :food='food' />
</div><script>略过...//【1】import CartControl from '../../../components/CartControl/CartControl'export default{略过...,components:{CartControl //【2】}}
</script>

效果:±按钮即是

在这里插入图片描述

二、实现加减按钮效果

1.pages/shop/goods/goods.vue加减按钮操作函数操作vuex,添加并改变food.count值实现购物车食物数量加减

<template>  <div class="cartcontrol"><!--1】点击并传值到计算属性,参数含义false:表示不是加(即减count);如果有food.count>0则显示减号 --><div class="iconfont icon-remove_circle_outline"  @click="updateCount(false)"></div><div class="cart-count">{{food.count}}</div><!--2】点击并传值到计算属性,参数含义:true表示加count --><div class="iconfont icon-add_circle" @click="updateCount(true)"></div></div>
</template>computed:{updateCount(isAdd){// 【3】触发action操作vuex,并向其传值this.$store.dispatch('updateFoodCount',{isAdd,food:this.food}) }}

2.创建mutation类型src/store/mutation-types.js

// 增加food中的count
export const INCREMENT_FOOD_COUNT = 'increment_food_count' 
// 减少food中的count
export const DECREMENT_FOOD_COUNT = 'decrement_food_count' 

3.actions.js

// 控制mutations
import {略过...,INCREMENT_FOOD_COUNT,//【1】加减购物产品数量DECREMENT_FOOD_COUNT,
} from './mutation-types.js'export default{
略过...,//【2】更新购物车食物数量updateFoodCount({commit},{isAdd,food}){if(isAdd){// 如果是true就是增加food.count数量commit(INCREMENT_FOOD_COUNT,{food})}else{// 否则就是减少commit(DECREMENT_FOOD_COUNT,{food})}}}

4.mutation.js

import {略过...
// 【1】以下3个购物车相关INCREMENT_FOOD_COUNT,DECREMENT_FOOD_COUNT,CLEAR_CART,RECEIVE_SEARCH_SHOPS
} from './mutation-types.js'
import Vue from 'vue' //【2】用于新增一个状态的属性,并能自动更新视图export default{略过...// 以下3个购物车相关// 【1】加购物车数量[INCREMENT_FOOD_COUNT](state,{food}){if(!food.count){//如果不存在数量属性则加一个// food.count=1//此操作虽能在food中加一个count属性,但视图无法更新/*Vue.set()参数:对象属性名属性值*/Vue.set(food,'count',1)// food.count++}else{//如果存在则直接加1food.count++}},// 【2】减购物车数量[DECREMENT_FOOD_COUNT](state,{food}){if(food.count){//如果购物车数量>0才进行减操作,防止数量为负food.count--}}}

5.效果:

  1. 点加会在状态中新增一个count属性,值为1,减号显示出来,继续点则数量增加
  1. 点减数量减少,到零则无法再点,且减号消失
    在这里插入图片描述

6.使用vue的动画给减号加旋转和隐藏效果

<!-- 动画旋转隐藏、显示 --><transition name="move"><!-- 点击并传值到计算属性,参数含义false:表示不是加(即减count);如果有food.count>0则显示减号 --><div class="iconfont icon-remove_circle_outline" v-show="food.count" @click="updateCount(false)"></div></transition>.icon-remove_circle_outlinedisplay: inline-blockpadding 6pxline-height 24pxfont-size 24pxcolor $green/*动画样式部分*/&.move-enter-active, &.move-leave-activetransition all .3s&.move-enter, &.move-leave-toopacity 0transform translateX(25px) rotate(180deg)

效果:

点加减0到1时减号会滚动渐显出来
1-0时,滚动渐隐消失

这篇关于vue外卖十七:商家详情-cartControl组件:购物车加减商品组件及功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/965190

相关文章

公共筛选组件(二次封装antd)支持代码提示

如果项目是基于antd组件库为基础搭建,可使用此公共筛选组件 使用到的库 npm i antdnpm i lodash-esnpm i @types/lodash-es -D /components/CommonSearch index.tsx import React from 'react';import { Button, Card, Form } from 'antd'

vue, 左右布局宽,可拖动改变

1:建立一个draggableMixin.js  混入的方式使用 2:代码如下draggableMixin.js  export default {data() {return {leftWidth: 330,isDragging: false,startX: 0,startWidth: 0,};},methods: {startDragging(e) {this.isDragging = tr

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

android 免费短信验证功能

没有太复杂的使用的话,功能实现比较简单粗暴。 在www.mob.com网站中可以申请使用免费短信验证功能。 步骤: 1.注册登录。 2.选择“短信验证码SDK” 3.下载对应的sdk包,我这是选studio的。 4.从头像那进入后台并创建短信验证应用,获取到key跟secret 5.根据技术文档操作(initSDK方法写在setContentView上面) 6.关键:在有用到的Mo

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

Android我的二维码扫描功能发展史(完整)

最近在研究下二维码扫描功能,跟据从网上查阅的资料到自己勉强已实现扫描功能来一一介绍我的二维码扫描功能实现的发展历程: 首页通过网络搜索发现做android二维码扫描功能看去都是基于google的ZXing项目开发。 2、搜索怎么使用ZXing实现自己的二维码扫描:从网上下载ZXing-2.2.zip以及core-2.2-source.jar文件,分别解压两个文件。然后把.jar解压出来的整个c

Toolbar+DrawerLayout使用详情结合网络各大神

最近也想搞下toolbar+drawerlayout的使用。结合网络上各大神的杰作,我把大部分的内容效果都完成了遍。现在记录下各个功能效果的实现以及一些细节注意点。 这图弹出两个菜单内容都是仿QQ界面的选项。左边一个是drawerlayout的弹窗。右边是toolbar的popup弹窗。 开始实现步骤详情: 1.创建toolbar布局跟drawerlayout布局 <?xml vers

js+css二级导航

效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Con

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页: