vue制作抓娃娃机的示例代码


Posted in Javascript onApril 17, 2020

去年为联通制作双十一活动,做四个小游戏:‘配对消消乐'、移动拼图、抓娃娃、倒计时。 现在先做来分享一下制作抓娃娃游戏时的经验 先上效果图

vue制作抓娃娃机的示例代码

游戏规则:在指定时间内抓到上图四张卡片为挑战成功。 现在直接说游戏主要内容:娃娃滚动、爪子向下抓取、抓到卡片 废话不多说直接上代码!(此样式是根据需求而定)

<!--布局样式-->
<div class="game">
  <!--爪子-->
  <div class="paw">
   <div class="pawer"></div>
   <div class="pawerPic">
   <img src="./../assets/img/zhuashou.png" class="lose" />
   <div class="win" v-if="gzShow2">
    <img :src="t_img" />
   </div>
   </div>
  </div>
  <!--区域-->
  <div class="area">
   <!--娃娃滚动-->
   <div id="pack" ref="pack">
   <div id="sel1" class="father" ref="imgs">
    <img
    v-for="img in imgs"
    :class="img.isSuc ? 'yes' : 'no'"
    :src="img.img"
    :key="img.id"
    :alt="img.isSuc"
    />
   </div>
   </div>
  </div>
  <span class="button" @click="zhua"></span>
  </div>
// css 
.game {
  width: 80%;
  height: 730px;
  background: url(./../assets/img/interface_1.png) no-repeat;
  background-size: 100%;
  animation: bg infinite 0.6s;
  position: relative;
  top: -60px;
  left: 0;
  z-index: 2;
  .paw {
  position: relative;
  top: 10%;
  }
  .pawer {
  width: 20px;
  background: rgb(170, 219, 254);
  height: 10px;
  position: absolute;
  top: 20px;
  left: 51%;
  margin-left: -15px;
  border-left: 1px solid rgba(42, 59, 156, 0.7);
  border-right: 1px solid rgba(42, 59, 156, 0.7);
  }
  .pawerPic {
  width: 95px;
  // height:85px;
  position: absolute;
  top: 30px;
  left: 51%;
  margin-left: -55px;
  img {
   width: 100%;
  }
  .win {
   position: absolute;
   bottom: -60px;
  }
  }
  .area {
  width: 100%;
  height: 500px;
  // overflow:hidden;
  position: absolute;
  // top:40px;
  left: 0;
  bottom: 40px;
  }
  /*娃娃滚动*/
  #pack {
  width: 80%;
  white-space: nowrap;
  overflow: hidden;
  position: absolute;
  bottom: 60px;
  left: 10%;
  #sel1 {
   display: block;
   img {
   display: block;
   width: 130px;
   height: 150px;
   float: left;
   margin-left: 20px;
   }
  }
  }
  .button {
  display: block;
  width: 130px;
  height: 90px;
  background: url(./../assets/img/button.png) no-repeat;
  background-size: 100%;
  position: absolute;
  bottom: 20px;
  left: 40%;
  }
 }

接下来就是卡片滚动,设置定时器,给卡片模块设置transform 让卡片从右向左匀速移动。

mounted() {
 this.wawa();
 this.talon = $(".pawerPic").offset().left + 100; // 首先获取爪子的位置(这里是固定的)
 }
wawa() {
  var pack = this.$refs.pack,
  width = $("#pack").width(),
  imgsWidth = (this.imgs.length * width) / 3,
  initLeft = 0;

  this.chatTimer = setInterval(function() {
  initLeft++;

  if (imgsWidth - initLeft < width + 60) {
   initLeft = 0;
  }
  $("#sel1").css({
   width: imgsWidth,
   transform: "translateX(-" + initLeft + "px)"
  });
  }, 15);
 },

再接着就是点击按钮控制爪子上下移动抓取卡片。 首先固定爪子的位置,上图代码中mounted里面的talon,然后设置爪子到下面的终止距离(差不多能够到卡片),为爪子设置动画改变top值,拉长绳子改变height值(因为爪子和绳子是分开的)。 当爪子到达下面时,获取每个卡片的位置,与爪子当前位置作比较,看爪子是否在某个卡片的指定抓取区域内来判断是否抓到卡片,然后上升。 上代码!!!


代码全部贴上了,很多功能都是因为自己的需求去加的。 第一次写文章,可能具体的表述不清楚。

到此这篇关于vue制作抓娃娃机的示例代码的文章就介绍到这了,更多相关vue 抓娃娃机内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
Easy.Ajax 部分源代码 支持文件上传功能, 兼容所有主流浏览器
Feb 24 Javascript
jquery获得下拉框值的代码
Aug 13 Javascript
Javascript中Event属性搜集整理
Sep 17 Javascript
javascript实现unicode与ASCII相互转换的方法
Dec 10 Javascript
详解Vue.js基于$.ajax获取数据并与组件的data绑定
May 26 Javascript
详解Vue.js搭建路由报错 router.map is not a function
Jun 27 Javascript
JS时间控制实现动态效果的实例讲解
Jul 31 Javascript
深入理解Node.js中通用基础设计模式
Sep 19 Javascript
AngularJS实现的简单拖拽功能示例
Jan 02 Javascript
微信小程序保存多张图片的实现方法
Mar 05 Javascript
JS中的算法与数据结构之链表(Linked-list)实例详解
Aug 20 Javascript
node获取客户端ip功能简单示例
Aug 24 Javascript
Vue+tracking.js 实现前端人脸检测功能
Apr 16 #Javascript
tracking.js实现前端人脸识别功能
Apr 16 #Javascript
electron 如何将任意资源打包的方法步骤
Apr 16 #Javascript
vue中keep-alive内置组件缓存的实例代码
Apr 16 #Javascript
详解Nuxt内导航栏的两种实现方式
Apr 16 #Javascript
javascript设计模式 ? 职责链模式原理与用法实例分析
Apr 16 #Javascript
vue下canvas裁剪图片实例讲解
Apr 16 #Javascript
You might like
PHP 学习路线与时间表
2010/02/21 PHP
PHP数据库万能引擎类adodb配置使用以及实例集锦
2014/06/12 PHP
php获取发送给用户的header信息的方法
2015/03/16 PHP
php的PDO事务处理机制实例分析
2017/02/16 PHP
javascript中HTMLDOM操作详解
2014/12/11 Javascript
javascript比较两个日期相差天数的方法
2015/07/23 Javascript
jQuery拖动元素并对元素进行重新排序
2015/12/30 Javascript
基于Javascript实现弹出页面效果
2016/01/01 Javascript
angularjs在ng-repeat中使用ng-model遇到的问题
2016/01/21 Javascript
JavaScript判断变量是否为数组的方法(Array)
2016/02/24 Javascript
JS实现添加,替换,删除节点元素的方法
2016/06/30 Javascript
关于vue.js v-bind 的一些理解和思考
2017/06/06 Javascript
bootstrap daterangepicker双日历时间段选择控件详解
2017/06/15 Javascript
jquery获取img的src值实例介绍
2019/01/16 jQuery
微信小程序搜索功能(附:小程序前端+PHP后端)
2019/02/28 Javascript
vue transition 在子组件中失效的解决
2019/11/12 Javascript
vue项目打包之开发环境和部署环境的实现
2020/04/23 Javascript
JS JQuery获取data-*属性值方法解析
2020/09/01 jQuery
小程序实现tab标签页
2020/11/16 Javascript
[43:36]Liquid vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python3 伪装浏览器的方法示例
2017/11/23 Python
Django的分页器实例(paginator)
2017/12/01 Python
Python利用pandas计算多个CSV文件数据值的实例
2018/04/19 Python
python Django 创建应用过程图示详解
2019/07/29 Python
Python之Class&amp;Object用法详解
2019/12/25 Python
pycharm 设置项目的根目录教程
2020/02/12 Python
python函数中将变量名转换成字符串实例
2020/05/11 Python
python 如何停止一个死循环的线程
2020/11/24 Python
Python实现对word文档添加密码去除密码的示例代码
2020/12/29 Python
红色连衣裙精品店:Red Dress Boutique
2018/08/11 全球购物
意大利在线购买隐形眼镜网站:VisionDirect.it
2019/03/18 全球购物
女娲补天教学反思
2014/02/05 职场文书
超市七夕促销活动方案
2014/08/28 职场文书
学习商务礼仪心得体会
2016/01/22 职场文书
CSS3 天气图标动画效果
2021/04/06 HTML / CSS
springboot利用redis、Redisson处理并发问题的操作
2021/06/18 Java/Android