PHP+Ajax手機移動端發紅包例項
基本流程:當輸入完紅包數量和總金額後,PHP會根據這兩個值進行隨機分配每個金額,保證每個人都能領取到一個紅包,且每個紅包金額不等,並且所有紅包金額總額等於總金額。
實現原理:
設定總金額為10元,有N個人隨機領取:
N=1 第一個
則紅包金額=X元;
N=2 第二個
為保證第二個紅包可以正常發出,第一個紅包金額=0.01至9.99之間的某個隨機數
第二個紅包=10-第一個紅包金額;
N=3 第三個
紅包1=0.01至9.99之間的某個隨機數
紅包2=0.01至(10-紅包1-0.01)的某個隨機數
紅包3=10-紅包1-紅包2
……
於是我們得到一個規律,在分配當前紅包金額時,先預留剩餘紅白所需最少金額,然後在0.01至總金額-預留金額間取隨機數,得到的隨機數就是當前紅包分配的金額。
實際應用中,程式先將紅包金額分配好,即發紅包時,紅包個數以及每個紅包的金額都分配好了,那麼使用者來搶紅包時,我們隨機給使用者返回一個紅包即可。
js程式碼:
$(function() { $("button").click(function() { $.ajax({ type: 'POST', url: 'bao.php', dataType: 'json', beforeSend: function() { $("#result").html('正在分配紅包'); }, success: function(json) { if (json.msg == 1) { var str = ''; var res = json.res; $.each(res, function(index, array) { str += '<p>第<span>' + array['i'] + '</span>個紅包,金額<span>' + array['money'] + '</span>元,餘額<span>' + array['total'] + '元</span></p>'; }); $("#result").html(str); } else { $("#result").html('資料出錯!'); } } }); }); });
bao.php原始碼:
$total=20;//紅包總金額 $num=10;// 分成10個紅包,支援10人隨機領取 $min=0.01;//每個人最少能收到0.01元 for ($i=1;$i<$num;$i++) { $safe_total=($total-($num-$i)*$min)/($num-$i);//隨機安全上限 $money=mt_rand($min*100,$safe_total*100)/100; $total=$total-$money; echo '第'.$i.'個紅包:'.$money.' 元,餘額:'.$total.' 元 '; } echo '第'.$num.'個紅包:'.$total.' 元,餘額:0 元';
本文轉自:
轉載請註明出處!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31560779/viewspace-2658297/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- PHP+Ajax微信手機端九宮格抽獎例項PHP
- vue移動端路由切換完整例項Vue路由
- 移動端div塊拖動效果程式碼例項
- 手機移動端點選超連結既可以撥打電話程式碼例項
- 移動端手機網站優化的11個注意事項網站優化
- Java-發紅包例項-繼承練習Java繼承
- 模擬發放紅包效果程式碼例項
- PHP+Ajax實現文章心情投票功能例項PHP
- 移動端判斷觸屏位置程式碼例項
- 移動端字型大小自適應程式碼例項
- 移動端頁面大小自適應程式碼例項
- 移動web開發之移動端真機測試Web
- 混合移動應用開發初級例項
- 手動建立Oracle例項Oracle
- 移動端安卓手機車牌識別SDK安卓
- android移動開發簡單的開發例項Android移動開發
- PHP+Ajax點選載入更多列表資料例項PHP
- 移動端點選彈出提示視窗程式碼例項
- 3.1.5.9 啟動遠端例項
- Flutter動畫例項——4缸發動機動畫Flutter動畫
- ecshop仿小米商城原始碼 帶手機移動端原始碼
- 【移動端開發】移動端開發基礎問題
- js實現的移動端貪吃蛇遊戲程式碼例項JS遊戲
- Flutter移動端實戰手冊Flutter
- 移動端開發模式模式
- 移動端開發技巧
- oracle手動建立另外一個例項Oracle
- Oracle10G手動建立例項Oracle
- 方向鍵控制元素移動程式碼例項
- 移動開發,Webapp 淘寶手機 rem 佈局移動開發WebAPPREM
- BCB 客戶端 tuxedo 開發例項客戶端UX
- 移動端水平滑動刪除程式碼例項
- 移動端(手機端)頁面自適應解決方案—rem佈局篇REM
- 移動端手機網站的怎樣優化?方法攻略篇網站優化
- js判斷移動端型別或者瀏覽器型別程式碼例項JS型別瀏覽器
- TRIZ 機械振動原理 例項
- 移動端開發小結
- SQL Server隱藏例項會導致Alwasy on手動故障轉移時報error 26SQLServerError