Vue实现购物小球抛物线的方法实例


Posted in Vue.js onNovember 22, 2020

本文介绍的是利用Vue实现购物小球抛物线的相关内容,下面话不多说了,来一起看看详细的介绍吧

css片段

.shop{
  position: fixed;
  top: 300px;
  left: 40px;
 }
 .ball{
  position: fixed;
  left: 32px;
  bottom: 22px;
  z-index: 200;
  transition: all 0.4s cubic-bezier(0.49, -0.29, 0.75, 0.41); /*贝塞尔曲线*/
 }
 .inner{
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background-color: rgb(0,160,220);
  transition: all 0.4s linear;
 }
 .cart{
  position: fixed;
  bottom: 22px;
  left: 32px;
  width: 30px;
  height: 30px;
  background-color: rgb(0,160,220);
  color: rgb(255,255,255);
 }

html片段

<div id="app">
  <ul class="shop">
   <li v-for="item in items">
    <span>{{item.text}}</span>
    <span>{{item.price}}</span>
    <button @click="additem">添加</button>
   </li>
  </ul>
 <div class="cart" style="">{{count}}</div>
  <div class="ball-container"><!--小球-->
   <div v-for="ball in balls">
    <transition name="drop" @before-enter="beforeDrop" @enter="dropping" @after-enter="afterDrop">
     <div class="ball" v-show="ball.show">
      <div class="inner inner-hook"></div>
     </div>
    </transition>
   </div>
  </div>
 </div>

js片段

<script>
  new Vue({
   el:"#app",
   data:{
    count: 0,
    items:[
     {
      text: "苹果",
      price: 15
     },
     {
      text: "香蕉",
      price: 15
     }
    ],
    balls: [ //小球 设为3个
     {
      show: false
     },
     {
      show: false
     },
     {
      show: false
     },
    ],
    dropBalls:[],
   },
   methods:{
    additem(event){
    this.drop(event.target);
    this.count ++;
    },
    drop(el){ //抛物
     for(let i=0;i<this.balls.length;i++){
      let ball= this.balls[i];
      if(!ball.show){
       ball.show = true;
       ball.el=el;
       this.dropBalls.push(ball);
       return;
      }
     }
    },
    beforeDrop(el) {/* 购物车小球动画实现 */
     let count = this.balls.length;
     while (count--) {
      let ball = this.balls[count];
      if (ball.show) {
       let rect = ball.el.getBoundingClientRect(); //元素相对于视口的位置
       let x = rect.left - 32;
       let y = -(window.innerHeight - rect.top - 22); //获取y
       el.style.display = '';
       el.style.webkitTransform = 'translateY('+y+'px)'; //translateY
       el.style.transform = 'translateY('+y+'px)';
       let inner = el.getElementsByClassName('inner-hook')[0];
       inner.style.webkitTransform = 'translateX('+x+'px)';
       inner.style.transform = 'translateX('+x+'px)';
      }
     }
   },
    dropping(el, done) { /*重置小球数量 样式重置*/
     let rf = el.offsetHeight;
     el.style.webkitTransform = 'translate3d(0,0,0)';
     el.style.transform = 'translate3d(0,0,0)';
     let inner = el.getElementsByClassName('inner-hook')[0];
     inner.style.webkitTransform = 'translate3d(0,0,0)';
     inner.style.transform = 'translate3d(0,0,0)';
     el.addEventListener('transitionend', done);
   },
    afterDrop(el) { /*初始化小球*/
     let ball = this.dropBalls.shift();
     if (ball) {
     ball.show=false;
     el.style.display = 'none';
    }
   }
  }
 })
 </script>

transtion属性可以查看官方文档,具体位置可以通过调试获得。

到此这篇关于Vue实现购物小球抛物线的文章就介绍到这了,更多相关Vue购物小球抛物线内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
vue中defineProperty和Proxy的区别详解
Nov 30 Vue.js
Vue.js桌面端自定义滚动条组件之美化滚动条VScroll
Dec 01 Vue.js
vue中封装axios并实现api接口的统一管理
Dec 25 Vue.js
浅析vue中的nextTick
Dec 28 Vue.js
vue3中轻松实现switch功能组件的全过程
Jan 07 Vue.js
详解vue3中组件的非兼容变更
Mar 03 Vue.js
vue中三级导航的菜单权限控制
Mar 31 Vue.js
Vue + iView实现Excel上传功能的完整代码
Jun 22 Vue.js
vue中利用mqtt服务端实现即时通讯的步骤记录
Jul 01 Vue.js
vue中 this.$set的使用详解
Nov 17 Vue.js
一起来看看Vue的核心原理剖析
Mar 24 Vue.js
vue ref如何获取子组件属性值
Mar 31 Vue.js
vue自定义插件封装,实现简易的elementUi的Message和MessageBox的示例
Nov 20 #Vue.js
详解vue 组件注册
Nov 20 #Vue.js
vue-drawer-layout实现手势滑出菜单栏
Nov 19 #Vue.js
Vue 打包的静态文件不能直接运行的原因及解决办法
Nov 19 #Vue.js
如何使用 vue-cli 创建模板项目
Nov 19 #Vue.js
深入了解Vue3模板编译原理
Nov 19 #Vue.js
vue 获取到数据但却渲染不到页面上的解决方法
Nov 19 #Vue.js
You might like
多文件上载系统完整版
2006/10/09 PHP
php中实现用数组妩媚地生成要执行的sql语句
2015/07/10 PHP
datePicker——日期选择控件(with jquery)
2007/02/20 Javascript
js操作select控件的几种方法
2010/06/02 Javascript
javascript获取下拉列表框当中的文本值示例代码
2013/07/31 Javascript
一个网页标题title的闪动提示效果实现思路
2014/03/22 Javascript
Javascript获取当前日期的农历日期代码
2014/10/08 Javascript
不同编码的页面表单数据乱码问题解决方法
2015/02/15 Javascript
AngularJS创建自定义指令的方法详解
2016/11/03 Javascript
js上传图片预览的实现方法
2017/05/09 Javascript
webpack热模块替换(HMR)/热更新的方法
2018/04/05 Javascript
Vue Echarts实现可视化世界地图代码实例
2019/05/07 Javascript
vue+elementUI实现表单和图片上传及验证功能示例
2019/05/14 Javascript
vue-resourc发起异步请求的方法
2020/02/11 Javascript
vue 解决兄弟组件、跨组件深层次的通信操作
2020/07/27 Javascript
介绍Python的Django框架中的静态资源管理器django-pipeline
2015/04/25 Python
python代码实现ID3决策树算法
2017/12/20 Python
教你使用python实现微信每天给女朋友说晚安
2018/03/23 Python
python使用PIL实现多张图片垂直合并
2019/01/15 Python
使用Python制作表情包实现换脸功能
2019/07/19 Python
python多进程重复加载的解决方式
2019/12/13 Python
TensorFlow MNIST手写数据集的实现方法
2020/02/05 Python
python 实现朴素贝叶斯算法的示例
2020/09/30 Python
如何基于python实现年会抽奖工具
2020/10/20 Python
运行python提示no module named sklearn的解决方法
2020/11/29 Python
python中numpy数组与list相互转换实例方法
2021/01/29 Python
HTML5中的autofocus(自动聚焦)属性介绍
2014/04/23 HTML / CSS
过程装备与控制工程专业个人的求职信
2013/12/01 职场文书
高等教育学自荐书范文
2014/02/10 职场文书
公安学专业求职信
2014/07/27 职场文书
2014年度党员自我评议
2014/09/13 职场文书
2014年大堂经理工作总结
2014/11/21 职场文书
婚宴邀请函
2015/01/30 职场文书
上班迟到检讨书
2015/05/06 职场文书
赞美教师的句子
2019/09/02 职场文书
java实现对Hadoop的操作
2021/07/01 Java/Android