看一下這次我們想要實現(xiàn)的效果:
小伙伴們可以點擊這個預覽鏈接,親手試試吧。
(如果發(fā)現(xiàn)了啥BUG猎物,還請麻煩悄悄的評論告訴我遏插。)
看過效果之后我們再確認一下我們要實現(xiàn)的幾個功能
- 點擊“開始抽獎”忱反,在名單中隨機抽取一位中獎人渤弛,并有閃爍切換的滾動效果祝拯。
- 點擊“再抽一次”,會開啟新一輪的抽獎她肯,并且不包含上一輪抽中的中獎人佳头。
- 全部人員都抽取完后,可以點擊“重新開始”開啟新一輪的抽獎晴氨,會重新將全部名單加載進來康嘉。
那么,我們提煉一下幾個重點
- 人員名單籽前,如何存放人員名單亭珍;
- 隨機,如何實現(xiàn)隨機抽戎濉肄梨;
- 切換,如何實現(xiàn)在候選人之間閃爍切換挠锥;
- 如何實現(xiàn)開始切換众羡,以及停止切換(抽中候選人);
- 不包含蓖租,如何排除上一輪已中獎名單粱侣;
如何存放人員名單:
- 使用中繼器羊壹,在頁面加載時,添加一個動作添加行齐婴。
如何實現(xiàn)隨機抽取
- 給每個人員一個隨機編碼油猫,然后進行排序,候選人的排序就被打亂了柠偶,就可以做到隨機的效果眨攘。
如何實現(xiàn)閃爍切換
- 中繼器設置分頁,一頁僅顯示一行信息嚣州,那么只要實現(xiàn)一定時間后翻到下一頁就可以實現(xiàn)切換了鲫售。
- 那么怎么實現(xiàn)循環(huán)切換呢?因為一般情況下頁面翻到最后一頁该肴,就會停止了情竹。那么我們就要在它翻到最后一頁的時候再添加一個動作,就是跳到第一頁匀哄,這樣就可以從第一頁開始繼續(xù)往后翻頁了秦效。
如何實現(xiàn)開始抽獎和停止抽獎
- 翻譯過來就是,怎么讓中繼器不停翻頁涎嚼,并在想要的時候停下阱州。
那么我們就要設置一個全局變量,我給它命名為 StopOrStart法梯,它將會有兩種賦值就是start和stop苔货。 - 當這個值不等于stop的時候,中繼器就一直翻頁立哑。那就要考慮什么動作能一直出發(fā)翻頁夜惭。這個仿佛是一個公式一樣,基本就是當狀態(tài)改變铛绰,當文本改變時诈茧。正好我們中繼器里需要有姓名、手機號捂掰,這兩樣就可以用文本框敢会,文本框就有當文本改變時的交互。另外這里很好的一個點是不同的人可能有相同的姓名这嚣,但手機號肯定不一樣鸥昏。所以我們在對顯示手機號的文本框上添加文本改變時的交互。翻譯一下就是疤苹,當顯示手機號的文本框改變時互广,只要全局變量StopOrStart不等于Stop,就不斷地翻頁。
那么讓它停下來就簡單了惫皱,就是讓全局變量在你需要的時候讓它變成是Stop就好了像樊。我在這個原型中設置了過三秒全局變量等于Stop,那么也可以是當點擊某個按鈕的時候全局變量等于Stop旅敷,翻頁就停止了生棍,那么當前頁就算是抽中的人選了。
那么翻頁停止后媳谁,又如何啟動抽獎呢涂滴?只要觸發(fā)某個動作時讓中繼器開始翻到下一頁,文本框改變了晴音,就又會觸發(fā)不停翻頁了柔纵。
如何在下一輪抽獎的時候排除之前的中獎人員
- 再下一次抽獎之前,將當前頁面的人員刪除锤躁。此時手機號碼的唯一性又派上用場了搁料,刪除中繼器中手機號碼等于當前文本框中的文本信息的行即可。
以上就是本原型的核心邏輯啦系羞,需要下載原型的小伙伴可以點擊這個預覽鏈接查看下載鏈接郭计。