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

基于vue3實現(xiàn)一個抽獎小項目

 更新時間:2023年01月23日 09:27:38   作者:曦12  
在公司年會期間我做了個抽獎小項目,非常棒,今天把他分享到腳本之家平臺,供大家學習參考,對vue3實現(xiàn)抽獎小項目感興趣的朋友一起看看吧

前言

實現(xiàn)目標數(shù)據(jù)保存:無后端,純前端實現(xiàn),瀏覽器刷新或者關(guān)閉數(shù)據(jù)不能丟失。姓名切換:點擊中部開始按鈕姓名快速切換。獎項切換:獎項為操作人員手動切換設(shè)置。歷史記錄:抽獎完成后需要有歷史記錄。數(shù)據(jù)導入:允許參與人員的表格導入。

數(shù)據(jù)保存

無后臺,純前端實現(xiàn)而且需要刷新關(guān)閉瀏覽器數(shù)據(jù)不丟失,很容易便會想到使用localStorage,localStorage存入的數(shù)據(jù)具有持久性,不會因為刷新或關(guān)閉瀏覽器而變化(除非手動刻意的清除),有別于sessionstorage,localStorage的生命周期是永久,sessionstorage是瀏覽器或者標簽頁關(guān)閉。

因為存入的數(shù)據(jù)不是單純的字符串,而是具有結(jié)構(gòu)性的對象數(shù)組,所以需要配合JSON.stringify與JSON.parse來使用。這是存入數(shù)據(jù)的方法:

localStorage.setItem("luckDrawHis", JSON.stringify(luckDrawHis));//JSON.stringify將json轉(zhuǎn)換為字符串

這是讀取數(shù)據(jù)的方法:

JSON.parse(localStorage.getItem("luckDrawHis"))//JSON.parse將字符串轉(zhuǎn)換為json

姓名切換

抽獎的方式是數(shù)據(jù)導入后,點擊中間的圓形開始按鈕,姓名便開始快速切換,再次點擊按鈕便停止姓名切換,彈出對話框顯示當前姓名以及設(shè)置的獎項。

切換姓名利用了vue的數(shù)據(jù)響應式原理。先獲取到所有的參與人員數(shù)據(jù),然后亂序處理,最后循環(huán)展示,我這里每個姓名展示的時間為50毫秒,你也可以自己設(shè)置。這里的數(shù)組亂序我使用了洗牌算法,其實就是利用Math.random獲取數(shù)組的隨機下標,然后與最后一個元素進行位置交換。

//洗牌算法(亂序數(shù)組)
function shuffle(arr) {
  let l = arr.length
  let index, temp
  while (l > 0) {
    index = Math.floor(Math.random() * l)
    temp = arr[l - 1]
    arr[l - 1] = arr[index]
    arr[index] = temp
    l--
  }
  return arr;
}
 
//循環(huán)列表
function forNameList(list) {
  list = shuffle(list);
  for (let i = 0; i < list.length; i++) {
    setTimeout(() => {
      if (!isStop.value) {
        curName.value = list[i].name;
        (i == list.length - 1) && (forNameList(nameList.value));//數(shù)組耗盡循環(huán)
      }
    }, 50 * i);
  }
}

獎項切換

獎項切換直接使用elementPlus的單選框即可。

歷史記錄

每次點擊抽獎出現(xiàn)結(jié)果時,將之前的抽獎結(jié)果取出來,然后把當前的結(jié)果添加到末尾。

點擊抽獎歷史按鈕時再將所有歷史數(shù)據(jù)取出來。

數(shù)據(jù)導入

由于需要導入人員表格數(shù)據(jù),這里我使用了xlsx插件與file-saver插件來實現(xiàn)。

首先是下載模板。

將事先準備好的表格模板放在項目的public目錄下。

點擊下載模板按鈕時直接調(diào)用以下方法即可,其中的saveAs是file-saver插件中的方法,傳入路徑與文件名即可。

import { saveAs } from 'file-saver';
//下載模板
function downTemp() {
    let fileName = "人員模板.xlsx";//文件名
    let fileUrl = "./template/";//文件路徑(路徑相對index.html)
    saveAs(fileUrl + fileName, fileName);
}

表格處理好,

點擊導入按鈕讀取表格數(shù)據(jù)時使用的是xlsx插件,下面是讀取數(shù)據(jù)的方法。

import * as XLSX from "xlsx";
//導入數(shù)據(jù)
function importData(e) {
    isLoading.value = true;
    let file = e.target.files[0]; //獲取事件中的file對象
    let fileReader = new FileReader(); //創(chuàng)建文件讀取器
    fileReader.onload = (event) => {
        let result = event.target.result; //獲取讀取的結(jié)果
        let workBook = XLSX.read(result, { type: "binary" }); //XLSX讀取返回的結(jié)果
        let jsonData = XLSX.utils.sheet_to_json(
            workBook.Sheets[workBook.SheetNames[0]]
        ); //將讀取結(jié)果轉(zhuǎn)換為json
        tabData.value = [];
        jsonData.forEach((j) => {
            tabData.value.push({
                name: j.姓名,
                age: j.性別,
                department: j.部門,
            });
        }); //處理成需要的數(shù)據(jù)格式
        localStorage.setItem("tabData", JSON.stringify(tabData.value));//數(shù)據(jù)存入本地
        tabDataS.value = JSON.parse(localStorage.getItem("tabData"));//取出數(shù)據(jù)
        emits("getNameList", tabData);
        isLoading.value = false;
    };
    fileReader.readAsBinaryString(file); //開始讀取文件
    ((document.getElementsByClassName("inp-xlsx")[0]).value = ""); //置空選中的文件
};

結(jié)語

  • 項目很簡單,但給我的時間很少,很多優(yōu)化的地方都沒做好,后面有時間了再優(yōu)化下,順便適配下移動端。
  • 原文地址:https://xiblogs.top/?id=53

到此這篇關(guān)于基于vue3實現(xiàn)一個抽獎小項目的文章就介紹到這了,更多相關(guān)vue3抽獎項目內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue中實現(xiàn)可編輯table及其中加入下拉選項

    vue中實現(xiàn)可編輯table及其中加入下拉選項

    這篇文章主要介紹了vue中實現(xiàn)可編輯table及其中加入下拉選項,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 基于Vue實現(xiàn)微前端的示例代碼

    基于Vue實現(xiàn)微前端的示例代碼

    這篇文章主要介紹了基于Vue實現(xiàn)微前端的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • vue雙向綁定及觀察者模式詳解

    vue雙向綁定及觀察者模式詳解

    這篇文章主要介紹了vue雙向綁定及觀察者模式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03
  • vue如何使用HMAC-SHA256簽名算法

    vue如何使用HMAC-SHA256簽名算法

    這篇文章主要介紹了vue使用HMAC-SHA256簽名算法的相關(guān)知識,本文給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • 淺談VUE項目打包后運行頁面一片白問題

    淺談VUE項目打包后運行頁面一片白問題

    本文主要介紹了淺談VUE項目打包后運行頁面一片白問題,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2023-01-01
  • Vue3中插槽(slot)用法匯總(推薦)

    Vue3中插槽(slot)用法匯總(推薦)

    這篇文章主要介紹了Vue3中插槽(slot)用法匯總,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • vue項目中main.js的用法

    vue項目中main.js的用法

    src/main.js是入口文件,主要作用是初始化vue實例并使用需要的插件, Vue.use()的作用就是讓它里面被注冊的組件能夠被全局使用,本文通過實例代碼介紹vue項目中main.js的用法,感興趣的朋友一起看看吧
    2023-10-10
  • vue 取出v-for循環(huán)中的index值實例

    vue 取出v-for循環(huán)中的index值實例

    今天小編就為大家分享一篇vue 取出v-for循環(huán)中的index值實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 一起來看看Vue的核心原理剖析

    一起來看看Vue的核心原理剖析

    這篇文章主要為大家詳細介紹了Vue的核心原理,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • vue輸入框組件開發(fā)過程詳解

    vue輸入框組件開發(fā)過程詳解

    這篇文章主要為大家詳細介紹了vue輸入框組件開發(fā)過程,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評論