Eu tenho um pequeno problema com a função jquery $ .ajax ().
Eu tenho um formulário onde cada clique no botão de rádio ou seleção no menu suspenso cria uma variável de sessão com o valor selecionado.
Agora - eu tenho um dos menus suspensos que tem 4 opções - o primeiro (com rótulo Nenhum) tem um valor = "" os outros têm seus ids.
O que eu quero que aconteça é a opção Nenhum (com valor em branco) para remover a sessão e outra para criar uma, mas somente se a sessão com este nome de seleção específico ainda não existir - já que todas as outras opções têm a mesma quantidade atribuída a ela - está apenas indicando qual foi selecionado.
Não tenho certeza se isso faz sentido - mas dê uma olhada no código - talvez isso o torne mais claro:
$("#add_ons select").change(function() {
// get current price of the addons
var order_price_addon = $(".order_price_addon").text();
// get price of the clicked radio button from the rel attribute
var add = $(this).children('option').attr('label');
var name = $(this).attr('name');
var val = $(this).val();
if(val == "") {
var price = parseInt(order_price_addon) - parseInt(add);
removeSession(name);
} else {
if(isSession(name) == 0) {
var price = parseInt(order_price_addon) + parseInt(add);
}
setSession(name, val);
}
$(".order_price_addon").html(price);
setSession('order_price_addon', price);
updateTotal();
});
então - em primeiro lugar, quando o menu #add_ons select aciona "mudança", obtemos alguns valores de alguns elementos para cálculos.
obtemos o atributo label da opção de nosso select que armazena o valor a ser adicionado ao total, nome do select para criar sessão com este nome e valor para depois verificar qual foi selecionado.
agora - verificamos se val == "" (o que indicaria que a opção Nenhum foi selecionada) e deduzimos o valor do total e também removemos a sessão com o nome do select.
Depois disso, é onde o problema começa - instrução else.
Do contrário - queremos verificar se a função isSession () com o nome de nosso seletor retorna 0 ou 1 - se retornar 0, então adicionamos ao total o valor armazenado no atributo label, mas se retornar 1 - isso sugere aquela sessão já existe - então nós apenas mudamos o valor desta sessão recriando-a - mas a quantidade não é adicionada a ela.
Agora a função isSession se parece com isto:
function isSession(selector) {
$.ajax({
type: "POST",
url: '/order.html',
data: ({ issession : 1, selector: selector }),
dataType: "html",
success: function(data) {
return data;
},
error: function() {
alert('Error occured');
}
});
}
Agora - o problema é - que não sei se o uso de "return" retornará o resultado da função - já que não parece funcionar - no entanto, se eu colocar os "dados" na seção success: no alerta - parece retornar o valor correto.
Alguém sabe retornar o valor da função e depois compará-lo na próxima instrução?
Obrigado pessoal - tentei da seguinte forma:
function isSession(selector) {
$.ajax({
type: "POST",
url: '/order.html',
data: ({ issession : 1, selector: selector }),
dataType: "html",
success: function(data) {
updateResult(data);
},
error: function() {
alert('Error occured');
}
});
}
então a função updateResult ():
função updateResult (dados) {resultado = dados; }
resultado - é a variável global - que estou tentando ler:
$("#add_ons select").change(function() {
// get current price of the addons
var order_price_addon = $(".order_price_addon").text();
// get price of the clicked radio button from the rel attribute
var add = $(this).children('option').attr('label');
var name = $(this).attr('name');
var val = $(this).val();
if(val == "") {
var price = parseInt(order_price_addon) - parseInt(add);
removeSession(name);
} else {
isSession(name);
if(result == 0) {
var price = parseInt(order_price_addon) + parseInt(add);
}
setSession(name, val);
}
$(".order_price_addon").html(price);
setSession('order_price_addon', price);
updateTotal();
});
mas por algum motivo - não funciona - alguma ideia?