Jump to content

Erro com ifs


vrodrigues

Recommended Posts

Boas tardes!

eu tenho este pedaço de código e não o que esta a acontecer de errado para ele não me correr os if em condiçoes.

Passo a explicar:

  • O php recebe por parâmetros as variáveis : $pesquisa( palavra que o utilizador quer pesquisar) - $latitude (Latitude de um local(calculo interno))- $longitude (Longitude de um local(calculo interno))- $raio(introduzido pelo utilizador) $cidade_input(cidade de pesquisa que um utilizador introduz) - $cate (categoria introduzida pelo utilizador)
  • Logo depois o php vai verificar qual a condição que satisfas o que o utilizador introduzir, ou seja, se o utilizador so introduzir a pesquisa e a categoria , o php vai verificar qual a condição que admite isto.

Problema:O php não verifica todas as condições , no máximo só verifica a primeira :S

aqui está p código:

if ($pesquisa != "" && $latitude == 0 && $longitude == 0 && $raio == 0 && $cidade_input == 0 && $cate == 0)
{
echo "pesquisa";
pesquisa($pesquisa);
} else if (($pesquisa != "") && ($latitude == 0 )&& ($longitude == 0 )&& ($raio == 0 )&& ($cidade_input != 0 )&& ($cate == 0)) {
echo "pesquisa+cidade";
pesquisa($pesquisa, 0, 0, 0, $cidade_input);
} else if ($pesquisa != 0 && $latitude != 0 && $longitude != 0 && $raio == 0 && $cidade_input == 0 && $cate == 0) {
echo "pesquida + geo";
pesquisa($pesquisa, $latitude, $langitude);
} else if ($pesquisa != 0 && $latitude != 0 && $longitude != 0 && $raio != 0 && $cidade_input == 0 && $cate == 0) { pesquisa($pesquisa, $latitude, $langitude, $raio);
} else if ($pesquisa != 0 && $latitude != 0 && $longitude != 0 && $raio != 0 && $cidade_input == 0 && $cate != 0) { pesquisa($pesquisa, $latitude, $langitude, 0, $cate);
} else if ($pesquisa != 0 && $latitude == 0 && $longitude == 0 && $raio != 0 && $cidade_input != 0 && $cate == 0) { pesquisa($pesquisa, 0, 0, $raio, $cidade_input);
} else if ($pesquisa != 0 && $latitude == 0 && $longitude == 0 && $raio != 0 && $cidade_input != 0 && $cate != 0) { pesquisa($pesquisa, 0, 0, $raio, $cidade_input, $cate);
} else if ($pesquisa != 0 && $latitude == 0 && $longitude == 0 && $raio != 0 && $cidade_input != 0 && $cate != 0) { pesquisa($pesquisa, 0, 0, 0, 0, $cate);
} else{ echo "Passou todos os if"; }

o que poderei estar a fazer de errado? o que estarei a fazer de errado e será que existe alguma forma de agilizar este código?

Edited by vrodrigues
Link to comment
Share on other sites

existe várias razões para ninguém te responder a este post

1º - ninguém é bruxo e sabe o que pretendes com o código

2º - não usaste correctamente os tags do geshi (code=php)

3º - o código é incompreensível

4º - não dizes o que acontece e o que é pretendido acontecer

IRC : sim, é algo que ainda existe >> #p@p
Link to comment
Share on other sites

2º - não usaste correctamente os tags do geshi (code=php)

3º - o código é incompreensível

Estes ainda se mantêm

"[Os jovens da actual geração]não lêem porque não envolve um telecomando que dê para mirar e atirar, não falam porque a trapalhice é rainha e o calão é rei" autor: thoga31

Life is a genetically transmitted disease, induced by sex, with death rate of 100%.

Link to comment
Share on other sites

Problema:O php não verifica todas as condições , no máximo só verifica a primeira :S

nao sera' porque todas as condicoes do primeiro if sao sempre validas?

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

então e se eu fizer por exemplo um if anterior para verificar se a $pesquisa está ok e so depois fizer as outras?

do género

if($pesquisa != ""){
if(latitude[..])
}


eu exprimentei trocar e fazer como falei em cima, no entanto ele só continua a entrar no primeiro if

Edited by brunoais
2x post junto
Link to comment
Share on other sites

antes do inicio do if mete $pesquisa=0;

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

e' so mesmo para experimentares se passa todos os ifs, se nao me engano tem que mostrar a mensagem :"Passou todos os if"

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

entao o erro e' das tuas variaveis, faz um eco 'as variaveis para vers qual e' o valor que elas tem, para conseguires localizar de onde vem o erro

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

eu nao sou bruxo de saber quais sao os valores que estas 'a espera, nem percebo o que fazem esses if's todos, tu e' que fizeste isso, tu e' que sabes o que e' suposto acontecer e quais sao os dados que deve receber e o que fazer com esses dados

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

Isto é o que é passado por parametros: XXX.php?params=gestor&lat=&log=&cat=&raio=&cidade=Aveiro

olha é isto que mostra: vem ai um if pesquisa=0 latitude= 0 longitude= 0 raio= 0 cidade_input= %Aveiro%Passou todos os if

ou seja ele esta a passar os parametros correctamente os valores estao correctos..Desculpa não que quis ofender e agradeço-te a ajuda xD, quando te disse que ja te mostrava , nao tava a dizer que eras bruxo, apenas que te ia mostrar o resultado e explicar.

Ha o pesquisa está a 0 proque está forçado....

Edited by vrodrigues
Link to comment
Share on other sites

onde estas a atribuir as variaveis do GET 'as $pesquisa ; $latitude; $longitude; $raio ;$cidade_input; $cate;

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

e que o valor dessas variaveis são atribuidos no php, por exemplo : $latitude = $_GET['lat'];

sim e' isso mesmo

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

xD pronto elas são todas atribuídas assim 😛

pronto ja esta resolvido o teu problema

Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.