博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
cartcontrol.vue购物车操作按钮
阅读量:6171 次
发布时间:2019-06-21

本文共 1516 字,大约阅读时间需要 5 分钟。

html代码

知识点:

  • 使用了vue2的动画实现方式-transition,这里主要在css上设计来配合vue2

  • cartcontrol这个模块主要通过三个小模块实现,删除按钮,显示数量块,增加按钮

  • 删除按钮和增加按钮都带有一个click方法,并且都有v-show来根据food的数量来控制显示,而显示数量块就只是单纯显示food的数量

js代码

知识点:

  • 引入vue模块,因为需要使用Vue.set方法

  • 接收来自goods.vue的food数据,然后使用

  • 有2个方法,一个是addCart,一个是decreaseCart,分别对应html代码中的@click

  • addCart方法,默认会传入event原生dom事件

    • 鉴于bsscrol插件的原因,需要return掉非bscrol的事件

    • 需要注意的是这里的food并没有count属性,所需要手动设置,虽然之前goods会将有count属性的food做自动处理,但是最开始的时候,所有food都没有count属性,并且cartcontrol是最开始触发对food的count属性进行添加的(点击一次就会对count++,增加一个food)

    • food数据是从父组件goods.vue传入的,所以对这个数据的修改,也能够反应到父组件,而这里使用Vue.set直接对vue的data进行对象数据写入,对food数据添加了一个count的属性,用来控制每一个food的被选中的数量,也因为shopcart.vue的数据也是从父组件goods.vue传入的,使用同一个food数据,从而关联到[shopcart.vue购物车]()的food的购买数量统计

  • decreaseCart方法,同上

css代码

知识点:

  • vue2的动画

    • Vue 提供了 transition 的封装组件,就是之前的<transition>

    • 这个动画是一个滚动淡入和淡出的效果

    • 首先,定义了这个动画效果的名字为move(<transition name="move">),并且将需要这个效果的内容用一个dom的div包裹起来,这个效果分2层,外层和内层inner(外层和内层用class来区分,通过增加一个内层class inner来区分)

    • 然后,设置原始的动画状态(外层和内层)

      • 外层设置了透明度为1和transform变形的3d位置

      • 内层设置了滚动角度和淡入淡出效果

    • 然后,设置vue的动画过渡属性

      • move-enter-active和move-leave-active

        • 这里设置匀速过渡效果是为了在动画进入过渡的结束状态和动画离开过渡的结束状态都是匀速过渡的变化效果,至于变化成什么效果需要看move-enter和move-leave-active

      • move-enter和move-leave-active

        • 这里设置外层的透明度为0(内层会继承)和变形的3d位置

        • 这里设置了内层滚动角度

        • 这么做实现了动画在进入过渡后和离开过渡后都会内外层,并且会出现内层一边滚动到指定位置然后消失的效果

  • font-size的使用

    • 因为使用行内元素,所以需要通过设置font-size为0来取消间隙

  • 对于一些设计上的图标过小(操作区域太小)影响用户操作体验的情况,需要增加一个padding来实现增大操作区域的目的

转载地址:http://drtba.baihongyu.com/

你可能感兴趣的文章
11G Oracle RAC添加新表空间时数据文件误放置到本地文件系统的修正
查看>>
从91移动应用发展趋势报告看国内应用现状
查看>>
【ORACLE技术嘉年华PPT】MySQL压力测试经验
查看>>
Linux下汇编调试器GDB的使用
查看>>
css溢出机制探究
查看>>
vue中如何实现后台管理系统的权限控制
查看>>
关于angularjs过滤器的理解
查看>>
vue 使用html2canvas将DOM转化为图片
查看>>
angular编辑-初始化变量失败
查看>>
jQuery源码解析之Data
查看>>
React Native Cannot read property 'bindings' of null (null)) 解决!
查看>>
同样的神经网络引擎,苹果A11芯片比华为麒麟970牛在哪?
查看>>
ucar-weex
查看>>
vuex 理解与应用
查看>>
ES6(3)-各种类型的扩展(数组、对象)
查看>>
mysql 分组
查看>>
Android JNI入门第三篇——jni头文件分析
查看>>
ubuntu server 10.4下NFS服务的配置
查看>>
nginx+php-FastCGI+mysql性能测试
查看>>
Openstack架构及基本概念理解
查看>>