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