我已经问了一次,但现在我不能以同样的方式解决它。我有一个smartwizard页面,当我点击完成后,我想通过ajax调用php函数并从服务器获取响应。
所以当我第一次点击它时,响应是我的页面的完整html代码,它不会执行我的功能,但它会重定向到另一个页面。 但是,当我再次返回此页面并再次单击它时,现在它会给出我想要的响应并执行该功能。
有没有人对为什么会这种情况有任何想法?
Ajax功能:
if(confirm('Adicionar ao Carrinho?')){
$.ajax({
async:false,
url:'booking/add_to_cart',
success:function(response){
alert(response);
},
error: function() {
console.log($.makeArray(arguments));
},
complete: function() {
console.log($.makeArray(arguments));
}
});
}else{
return false;
}
我的php控制器功能:
public function add_to_Cart(){
if(!isset($_SESSION['user_data'])){
echo "Tem de fazer login para adicionar ao carrinho";
exit();
}
$detalhes_viagem=serialize($_SESSION['detalhes_viagem']);
$idcliente=$_SESSION['user_data']['idcliente'];
if(isset($_SESSION['hotel'])){
$preco_hotel=$_SESSION['hotel']['preco_total'];
$hotel=serialize($_SESSION['hotel']);
unset($_SESSION['hotel']);
}else{
$preco_hotel=0;
$hotel="FALSE";
}
$voo="FALSE";
if(isset($_SESSION['rent'])){
$preco_rent=$_SESSION['rent']['preco_total'];
$rent=serialize($_SESSION['rent']);
unset($_SESSION['rent']);
}else{
$preco_rent=0;
$rent="FALSE";
}
if(isset($_SESSION['trans'])){
$preco_trans=$_SESSION['trans']['preco_total'];
$trans=serialize($_SESSION['trans']);
unset($_SESSION['trans']);
}else{
$preco_trans=0;
$trans="FALSE";
}
if(isset($_SESSION['extras'])){
$preco_extras=$_SESSION['extras']['preco_total'];
$extras=serialize($_SESSION['extras']);
unset($_SESSION['extras']);
}else{
$preco_extras=0;
$extras="FALSE";
}
$preco_total=$preco_hotel+$preco_rent+$preco_trans+$preco_extras;
$this->model->add_to_cart($hotel,$voo,$rent,$trans,$extras,$preco_total,$idcliente,$detalhes_viagem);
echo "something";
exit();
}
我的模型函数只是在数据库中插入这些值
当我在设置所需的会话后首次进入页面时,会发生这种情况,但这不起作用,尽管ajax执行成功功能。当我再次进入该页面时,alredy 100%工作。
答案 0 :(得分:0)
使用jquery
尝试此操作$(document).ready(function(){
if(confirm('Adicionar ao Carrinho?')){
$.ajax({
async:false,
url:'booking/add_to_cart',
success:function(response){
alert(response);
},
error: function() {
console.log($.makeArray(arguments));
},
complete: function() {
console.log($.makeArray(arguments));
}
});
}else{
return false;
}
});