使用Vue解决一下吃饭选择困难症

简介: 使用Vue解决一下吃饭选择困难症

每到中午,我就会陷入一个困境,不知道吃什么,今天和同事讨论了一下,我发现并不止我一个人这样,作为一名小白程序员,我毅然决然的准备使用代码解决这个问题,今天我们就使用Vue解决一下吧

效果图


image.png

页面结构

我们的页面结构是一个盒子用于存放我们喜欢的菜品,一个是用于存放开始选择和停止选择的按钮的盒子,开始选择和停止选择的按钮分别绑定了开始选择菜品事件,当我们点击的时候存放菜品的盒子会开始跳动,当我们点击停止的时候,存放菜品的盒子就会停止跳动,然后就会呈现出我们今天要吃的菜品,完美解决我们吃饭纠结的问题

<div id="app">
    <div class="Exhibition">{{food[foodIdx]}}</div>
    <div class="btns">
      <button @click="start">开始</button>
      <button @click="stop">停止</button>
    </div>
  </div>

样式

我们对其样式做一些调整

#app {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  }
  .Exhibition {
    width: 200px;
    height: 200px;
    border: 1px solid #000;
    background: #fff;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
  }
  .btns {
    margin-top: 20px;
    display: flex;
  }
   button {
      margin-right: 10px;
    }

逻辑实现

我们声明三个变量,food变量用于存放我们喜欢吃的菜品,这样避免了我们选择到自己不喜欢吃的菜,foodIdx是菜品的下标,主要用于变动显示的菜品,timer是存放变动菜品的定时器

export default {
  data() {
    return {
    //这里可以放我们喜欢菜品
      food: [
        "大米饭",
        "瓜丝儿",
        "山鸡丁儿"
      ],
      //菜品下标
      foodIdx: 0,
      //菜品定时器
      timer: null,
    };
  },
  watch: {},
  methods: {
 //开始选择菜品
    start() {
    //先清除一下菜品定时器,防止多次点击开始
      clearInterval(this.timer);
     //实现菜品的变换我们这里是通过周期性定时器执行随机获取菜品下标方法,使得菜品可以变换
      this.timer = setInterval(() => {
        this.getFood();
      }, 50);
    },
    //获取菜品下标方法
    getFood() {
    //最小值
      const Min = 0;
      //菜品列表最大值,因为length是整个列表的长度,但是下标是从零开始的所以需要减去1
      const Max = this.food.length - 1;
      //通过Math函数方法动态的获取最大值和最小值之间的值,作为菜品下标并赋值,使得页面上的菜品刷新
      this.foodIdx = Math.round(Math.random() * (Max - Min) + Min);
    },
    //停止菜品选择
    stop() {
    //我们是通过周期性定时器实现菜品的变化,所以当我们一清除周期性定时器,菜品变换自然而然的也停止了,页面上就是我们今天随机选择的菜品
      clearInterval(this.timer);
    }
  }
};

代码我放到码上掘金上了,有兴趣的朋友们,大家可以看一看!

image.png

坚持努力,无惧未来!

相关文章
|
2天前
|
缓存 JavaScript 前端开发
《基础篇第4章:vue2基础》:使用vue脚手架创建项目
《基础篇第4章:vue2基础》:使用vue脚手架创建项目
11 3
|
4天前
|
JavaScript 前端开发 开发者
Vue v-for 进阶指南:in 与 of 的区别及应用场景 | 笔记
Vue.js 中的 v-for 是强大的遍历指令,但其中的 in 和 of 关键字往往被开发者忽视。尽管它们的用法相似,但适用的场景和数据结构却各有不同。本文将详细探讨 v-for 中 in 和 of 的区别、适用场景以及在实际开发中的最佳使用时机。通过理解它们的差异,你将能够编写更加高效、简洁的 Vue.js 代码,灵活应对各种数据结构的遍历需求。
40 6
|
2天前
|
缓存 JavaScript
Vue 中 computed 与 method 的区别
【10月更文挑战第15天】computed 和 method 是 Vue 中两个重要的选项,它们在功能和特点上存在着明显的区别。理解并合理运用它们的区别,可以帮助我们构建更高效、更具可维护性的 Vue 应用。在实际开发中,要根据具体情况灵活选择使用,以满足不同的需求。
5 2
|
2天前
|
JavaScript 搜索推荐 UED
vue的自定义指令
【10月更文挑战第14天】Vue 自定义指令为我们提供了一种强大的工具,使我们能够更灵活地控制和扩展 Vue 应用的行为。通过合理地使用自定义指令,可以提高开发效率,增强应用的功能和用户体验。
|
3天前
|
JavaScript
|
5天前
|
缓存 JavaScript 前端开发
Vue 中动态导入的注意事项
【10月更文挑战第12天】 在 Vue 项目中,动态导入是一种常用的按需加载模块的技术,可以提升应用性能和效率。本文详细探讨了动态导入的基本原理及注意事项,包括模块路径的正确性、依赖关系、加载时机、错误处理、缓存问题和兼容性等,并通过具体案例分析和解决方案,帮助开发者更好地应用动态导入技术。
|
5天前
|
JavaScript API
vue 批量自动引入并注册组件或路由等等
【10月更文挑战第12天】 vue 批量自动引入并注册组件或路由等等
|
5天前
|
JavaScript 算法 前端开发
深入剖析Vue中v-for的使用及index作为key的弊端
深入剖析Vue中v-for的使用及index作为key的弊端
13 2
|
4天前
|
JavaScript UED
Vue + ElementUI 实现动态添加和删除表单项的多层嵌套表单
【10月更文挑战第5天】本示例展示了如何在 Vue.js 中使用 Element UI 组件实现动态添加和删除嵌套表单项。该表单包含设备信息、设备部位及其对应的任务列表,支持用户动态添加设备部位和任务,并提供相应的表单验证规则。
24 0
Vue + ElementUI 实现动态添加和删除表单项的多层嵌套表单
|
5天前
|
JavaScript
《进阶篇第9章》学习vuex知识点后练习:求和案例_纯vue版代码
《进阶篇第9章》学习vuex知识点后练习:求和案例_纯vue版代码
11 1

相关实验场景

更多