【做个小玩意】基于Vue的人生解答书

本文介绍了一个使用Vue.js创建的简单应用——“人生解答书”。该应用通过输入问题并随机返回答案的方式提供娱乐体验。文章详细记录了从项目初始化到界面搭建、数据处理直至最终部署的全过程。

没事干有点无聊,两个钟来个极限编程,用vue做一个人生解答书的小玩意,顺便边做边记录过程

Step 1. 建立Vue项目模板

直接命令建立项目

vue init webpack-simple answerbook

建立完以后进入目录

npm install

然后跑一下

npm run dev

ok~

Step 2. 原型图

谋定而后动,拿墨刀做个简单的原型图(啊啊啊没开QQ没截图工具 又浪费几分钟开QQ)

主要流程就是:

1. 进入页面1 输入个人的问题,点击翻开答案
2. 进入页面2 随机读取答案显示(当然随机啊哈哈不然还真的解答问题咩)
下面顺便放个二维码宣传下

Step 3. 拼界面

其实就两个界面,用vue-route的话有点小题大做了,实际问题实际分析,根据step来控制v-show就好了

<template>
  <div id="app">
    <div class="page" v-show="step == 1">
      <div class="center">
        <div class="top">
          <h1>答 案 之 书</h1>
          <h3>The Book Of Answers</h3>
        </div>
        <div class="mid">
          <h3> What's Your Question ? </h3>
          <input type="text" v-model="question"/><br/>
          <button class="submitBtn" @click="showAnswer">翻开答案</button>
        </div>
      </div>
    </div>
    <div class="page" v-show="step == 2">
        <div class="center">
          <div class="top">
            <h1>我 的 问 题</h1>
            <h3>{{ question }}</h3>
          </div>
          <div class="mid">
            <h3> 肯定是你啊! </h3>
            <h4> Fucking You </h4>
            <button class="submitBtn" @click="showQuestion">再問其他</button>
          </div>
          <div class="bottom">
          </div>
        </div>
    </div>
  </div>
</template>

<script>
export default {
  name: 'app',
  data () {
    return {
      step: 1,
      question: ""
    }
  },
  methods: {
    showAnswer (){
      this.step = 2;
    },
    showQuestion (){
      this.step = 1;
    }
  }
}
</script>

<style lang="scss">
#app {
  font-family: 'Avenir', Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}

.page {
  .center{
    width:100%;
    text-align:center;
  }
  .top,.mid,.bottom{
    float:left;
    width:100%;
    height:180px;
  }
}
</style>

大概页面出来了, 数据先用hard code

Step 4. 拿数据

然后想想答案的数据怎么来了,大概100个随机答案的话,平均5个字一个答案,500个字就大概1KB,加上格式什么的2KB对于手机端来说也不算负担重,那就不写服务端了,直接静态写在里面。

var data = ["是的","不是","放弃吧","肯定是你啊"];
module.exports = exports = data;

这个就是答案的数据来源了

然后在App.vue <script>改成:

import answersData from './data/data.js'
export default {
  name: 'app',
  data () {
    return {
      step: 1,
      question: "",
      answer: ""
    }
  },
  methods: {
    showAnswer (){
      this.step = 2;
    },
    showQuestion (){
      this.step = 1;
      this.answer = answersData[Math.floor(Math.random() * answersData.length)];
    }
  }
}

还有前面template中 hard code的答案显示要改成 {{ answer }}

Step5. 美化

现在美化一下

 

美化完就成了这个样子 有点感觉了(具体代码随后放上码云吧)

Step6. 部署

部署的话服务器什么的自己准备好吧,然后命令:

npm run build

build完以后把 index.html和dist 丢上去服务器就行啦~~~~

 

测试一下吧:

macauapper.bananac.tech

 

下班咯~周末愉快

转载于:https://my.oschina.net/u/203607/blog/861621

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值