Php 将客户端数据传递给服务器端方法

Php 将客户端数据传递给服务器端方法,php,javascript,jquery,ajax,countdown,Php,Javascript,Jquery,Ajax,Countdown,我有一个JavaScript文件,它使用json数据检查出价 现在我遇到的问题是,倒计时插件有一个onExpiry函数,它不允许您传递参数,当您执行此操作时,在计数器过期之前调用回调。在倒计时结束时,它应该将拍卖设置为赢,提醒用户并将他们添加到赢家表中。这大部分都是由php处理的,但是我所做的函数需要传递拍卖id和用户名,但是如果不传递参数,我想不出怎么做。这是我目前掌握的代码 是PHP函数: function isWon($user, $auction){ $this->

我有一个JavaScript文件,它使用json数据检查出价

现在我遇到的问题是,倒计时插件有一个onExpiry函数,它不允许您传递参数,当您执行此操作时,在计数器过期之前调用回调。在倒计时结束时,它应该将拍卖设置为赢,提醒用户并将他们添加到赢家表中。这大部分都是由php处理的,但是我所做的函数需要传递拍卖id和用户名,但是如果不传递参数,我想不出怎么做。这是我目前掌握的代码

是PHP函数:

 function isWon($user, $auction){
        $this->load->model('Auction_model', 'Auction');
        $this->load->model('Bid_model', 'Bid');
        $this->load->model('Customer_model', 'Customer');

        $makeWon = $this->Auction->isWon($auction);
        $customer = $this->Customer->getByUsername($user);

        if ($makeWon){
            $json = array(
                'success' => 'Congratulations '.$user.' You have won.',
            );
        }

        echo json_encode($json);

    }
Common.Js

function checkBids(){

    var id = $('div.auction').attr('id'); 
    $.ajax({
        url: 'http://localhost/tinybid/index.php/auction/auctiondata',
        dataType: 'json',
        success: function(json) {
            for (var i = 0; i < json.length; i++) {

                $('#auction'+json[i]['i']+' li.user').html(json[i]['u']);
                $('#auction'+json[i]['i']+' li.curPrice').html(json[i]['p']);
                if (typeof json[i]['t'] =='number'){
                    $('#auction'+json[i]['i']+' li.timer').countdown({until: startTimer(json[i]['i'],json[i]['t']), onExpiry: isWon}); 
                }
            }
        }

    }); 
}
function startTimer(auction, stamp){
    var time= new Date();
    time.setTime(stamp*1000);
    $('#auction'+auction+' li.timer').countdown('change', {until: time}); 

}

function isWon(user, auction){
    if (user){
        $.ajax({
            url: 'http://localhost/tinybid/index.php/auction/isWon/'+user+'/'+auction,
            dataType: 'json',
            success: function(json) {
                if (json['success']){   
                    alert(json['success'])
                }
            }

        }); 
    }
}
这是创建倒计时的最佳方式,还是更好、更干净的方式? 如果这是最好的方法,我如何才能让所有函数都工作lol:)

您不需要“onExpiry”来传递参数。 首先,您可以随时访问函数

onExpiry : function(){  isWon(user, auction); }
从而有效地在annonymous函数实现中传递参数。 但我通常只是简单地添加一个隐藏的输入字段

<input id="user_id" type="hidden"/>
<input id="auction_id" type="hidden"/>
然后用ajax将其传递给服务器,或者像这样直接用ajax传递

 $.ajax({
            url: 'http://localhost/tinybid/index.php/auction/isWon/'+user+'/'+auction,
            dataType: 'json',
            data:{user_id:$("#user_id").val(), auction_id:$("#auction_id").val()}, 
            success: function(json) {
                if (json['success']){   
                    alert(json['success'])
                }
            }
顺便说一下,请注意,在您的示例中,“URL”很奇怪。应该从“//”开始,中间不要包含“index .php”。如果我可以拥有你的文件层次结构,我也可以解决这个问题

var user_id = $("#user_id").val();
var auction_id =  $("#auction_id").val();
 $.ajax({
            url: 'http://localhost/tinybid/index.php/auction/isWon/'+user+'/'+auction,
            dataType: 'json',
            data:{user_id:$("#user_id").val(), auction_id:$("#auction_id").val()}, 
            success: function(json) {
                if (json['success']){   
                    alert(json['success'])
                }
            }