欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用vue編寫一個點擊數(shù)字計時小游戲

 更新時間:2016年08月31日 08:42:06   作者:qttttt  
這篇文章主要為大家詳細介紹了使用vue編寫一個點擊數(shù)字計時小游戲,具有一定的參考價值,感興趣的小伙伴們可以參考一下

使用vue編寫一個點擊數(shù)字計時小游戲,列入你在文本框中輸入3,點擊開始會生成一個3行3列的表格,表格數(shù)據(jù)為1-9隨機排列,這時候從1開始點擊,按順序點到9,當(dāng)按正確順序點擊完畢,會提示所用的時間,如果順序沒有按對,會提示游戲結(jié)束. 

1.首先下載vue源碼,下載地址http://cn.vuejs.org 

2.jquery是在面向dom操作,而vue是面向數(shù)據(jù)操作的,所以使用vue最好不要去操作dom,盡量發(fā)揮出vue的獨到之處,(如果使用過angularjs可能更容易理解) 

3.建立一個普通的html文件,在頭部引用vue的源文件

<head>
  <meta charset="utf-8" />
  <title></title>
  <script type="text/javascript" src="js/vue.js"></script>
</head> 

4.簡單的頁面 

1)首先v-model,數(shù)據(jù)的雙向綁定,根據(jù)你文本框輸入的值變化而變化. 

2)@click綁定一個click事件,其中@是v-on的縮寫.當(dāng)然綁定事件可以帶參數(shù)例如@click='time(item)'. 

3)v-for="(index, item) in list",循環(huán)數(shù)組,index為數(shù)組的角標(biāo),item為數(shù)組中的值. 

可以看一下vue文檔進一步了解. 

<body>
 <div id="play">
  <span>輸入數(shù)字,點擊開始,會生成對應(yīng)輸入數(shù)字的表格,從表格中數(shù)字1開始點擊,按順序點擊到最后....</span><br />
  <input type="number" v-model="num" />
  <button @click='arr'>開始</button>
  <br />
  <div v-for="(index, item) in list">
  <template v-if="index % num == 0 && index!=0"><br><br><br></template>
  <div style="float: left;"><button class="ibutton" @click='time(item)'>{{item}}</button></div>
  </div>
 </div>
</body>

5.vue操作 

1)首先要new出一個Vue的實例,el綁定你的dom,這里用id作為標(biāo)識 

2)data這是vue要操作的數(shù)據(jù),num文本框的值(默認為2),list[]根據(jù)文本框值,生成的list,startTime點擊表格的開始時間,endTime點擊表格的結(jié)束時間,checkNum當(dāng)前選中的數(shù)字. 

3)methods中有兩個方法arr用來根據(jù)文本框的值,生成一個數(shù)組,生成一個文本框值的平方長度,且不會重復(fù)的數(shù)組,數(shù)組的值為1-文本框值的平方,加入文本框的值為3,則生成的數(shù)組長度為9,數(shù)組的內(nèi)容為1-9且不重復(fù). 

time計算點擊的開始時間和結(jié)束時間,用check]Num來控制點擊的順序.

<script>
 new Vue({
  el: '#play',
  data: {
  num: 2,
  list: [],
  startTime: 0,
  endTime:0,
  checkNum:0
  },
  methods: {
  arr: function() {
   if(this.num > 20){
   alert('數(shù)值過大,瀏覽器會死掉,最好不要大于20');
   return;
   }
   this.checkNum = 0;
   var arrlength = this.num * this.num;
   var arr = new Array(arrlength);
   var index = 0;
   for(var i = 1; i <= arrlength; i++) {
   //生成隨機數(shù)
   var num = Math.random(); //Math.random():得到一個0到1之間的隨機數(shù)
   num = Math.ceil(num * arrlength); //num*?的取值范圍在0~?之間,使用向上取整就可以得到一個1~?的隨機
   if(arr[0] != 0) {
    var flag = false; // 控制是否存在重復(fù)元素
    // 遍歷生產(chǎn)數(shù)組中的元素
    for(var j = 0; j < arr.length; j++) {
    if(num != arr[j]) {
     flag = true;
    } else {
     flag = false;
     break;
    }
    }
    if(flag == true) {
    arr[index++] = num;
    } else {
    // 發(fā)現(xiàn)有重復(fù)元素重新產(chǎn)生新的隨機數(shù)
    i--;
    }
   } else {
    arr[index++] = num;
   }
   
   }
   this.list = arr;
  },
  time: function(item){
   if(this.checkNum+1 != item){
   alert('game over');
   this.checkNum = 0;
   return; 
   }
   var date = new Date();
   if(item == 1){
   this.startTime = date.getTime();
   }
   if(item == this.num * this.num){
   this.endTime = date.getTime();
   var useTime = ((this.endTime - this.startTime)/1000).toFixed(2);
   alert('使用了'+useTime+'秒');
   this.checkNum = 0;
   return;
   }
   this.checkNum = item;
  }
  }
 })
</script>

6.css代碼 

<style>
 .ibutton{
  margin-top: 10px;
  margin-left: 10px;
  color: #fff;
  border: 1px solid #8a6de9;
  background-color: #8a6de9;
  font-size: 14px;
  padding: 6px 12px;
  border-radius: 7px;
  width: 50px;
  height: 40px;
 }
</style>

7.在某些特定的場景使用vue來完成一個功能要比jquery簡單的多,但是jquery還是很強大的,根據(jù)不同的場景運用不同的技術(shù),更快更好的完成自己想要的功能.

本文已被整理到了《Vue.js前端組件學(xué)習(xí)教程》,歡迎大家學(xué)習(xí)閱讀。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解vue父子組件關(guān)于模態(tài)框狀態(tài)的綁定方案

    詳解vue父子組件關(guān)于模態(tài)框狀態(tài)的綁定方案

    這篇文章主要介紹了詳解vue父子組件關(guān)于模態(tài)框狀態(tài)的綁定方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • Vue中金額、日期格式化插件@formatjs/intl的使用及說明

    Vue中金額、日期格式化插件@formatjs/intl的使用及說明

    這篇文章主要介紹了Vue中金額、日期格式化插件@formatjs/intl的使用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 項目中Axios二次封裝實例Demo

    項目中Axios二次封裝實例Demo

    vue項目經(jīng)常會用到axios來請求數(shù)據(jù),那么首先肯定需要對這個請求方法進行一個二次封裝,這篇文章主要給大家介紹了關(guān)于項目中Axios二次封裝的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • 詳解Vue2.0組件的繼承與擴展

    詳解Vue2.0組件的繼承與擴展

    這篇文章主要介紹了詳解Vue2.0組件的繼承與擴展,主要分享slot、mixins/extends和extend的用法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • Vue之beforeEach非登錄不能訪問的實現(xiàn)(代碼親測)

    Vue之beforeEach非登錄不能訪問的實現(xiàn)(代碼親測)

    這篇文章主要介紹了Vue之beforeEach非登錄不能訪問的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • vue之proxyTable代理超全面配置流程

    vue之proxyTable代理超全面配置流程

    這篇文章主要介紹了vue之proxyTable代理超全面配置流程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue中粘貼板clipboard的使用方法舉例

    vue中粘貼板clipboard的使用方法舉例

    在Web應(yīng)用程序中剪貼板(Clipboard)操作是非常常見的操作之一,這篇文章主要給大家介紹了關(guān)于vue中粘貼板clipboard使用方法的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • Vue3在Setup中使用axios請求獲取的值方式

    Vue3在Setup中使用axios請求獲取的值方式

    這篇文章主要介紹了Vue3在Setup中使用axios請求獲取的值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue 組件的封裝之基于axios的ajax請求方法

    vue 組件的封裝之基于axios的ajax請求方法

    今天小編就為大家分享一篇vue 組件的封裝之基于axios的ajax請求方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • 基于vue中css預(yù)加載使用sass的配置方式詳解

    基于vue中css預(yù)加載使用sass的配置方式詳解

    下面小編就為大家分享一篇基于vue中css預(yù)加載使用sass的配置方式詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03

最新評論