温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么用PHP+Ajax实现手机移动端发红包功能

发布时间:2021-09-04 14:18:55 来源:亿速云 阅读:123 作者:chen 栏目:开发技术

本篇内容介绍了“怎么用PHP+Ajax实现手机移动端发红包功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

怎么用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 元';

“怎么用PHP+Ajax实现手机移动端发红包功能”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI