Test du type d'une variable

Résolu/Fermé
zeOoo
Messages postés
29
Date d'inscription
vendredi 20 février 2009
Statut
Membre
Dernière intervention
14 juin 2009
- 16 mars 2009 à 15:32
zeOoo
Messages postés
29
Date d'inscription
vendredi 20 février 2009
Statut
Membre
Dernière intervention
14 juin 2009
- 17 mars 2009 à 11:09
Bonjour,
je souhaite effectuer une recherche de commande pour en afficher les informations pour cela je fais une liste déroulante que me donne le choix entre une recherche par numéro ou par fournisseur. selon le cas choisis j'affiche dans une liste déroulante, sur la page appelé dans mon action, soit tout les numéro de commande soit le nom de tout les fournisseur chez qui une commande a été passé. du coup sur la page ou je dois afficher les infos je test si la valeur sélectionné dans la liste déroulante est un entier ou une chaine mais ca marche pas

voila mon code:

if (is_string($_POST['CdeRech']))// == 'frs')
{
$req="select distinct numcde, nomF from commande c, fournisseurs f where c.numF=f.numF ;";
$res= mysql_query($req) or die ('Erreur num : '.mysql_error() );
$data=mysql_fetch_row($res);

$req1="select numCde, dateCde, etatCde from commande c, fournisseurs f where c.numF = f.numF AND nomF='$data[1]';";
$query=mysql_query($req1) or die ('Erreur SelectInfo : '.mysql_error() );

while($request=mysql_fetch_array($query))
{

echo"<tr>
<td width='119' class='Style5'><div align='right'>Numéro Commande :</div></td>
<td colspan='2' class='Style5'>
<div align='left'>
<input type='text' name='numCde' size='10' value='$request[0]'/>
</div>
</td>

<td width='119' class='Style5'><div align='left'>Date Commande :</div></td>
<td colspan='2' class='Style5'>
<div align='left'>
<input type='text' name='dateCde' value='$request[1]'/>
</div>
</td>

<td width='127' class='Style5'><div align='left'>Etat Commande :</div></td>
<td width='506' colspan='2' class='Style5'>
<div align='left'>
<input type='text' name='etatCde' value='$request[2]'/>
</div>
</td>
</tr>";
}
}
else
{
$req1="select numCde, dateCde, etatCde from commande where numCde='".$_POST['CdeRech']."';";
$query=mysql_query($req1) or die ('Erreur SelectInfo : '.mysql_error() );
$request=mysql_fetch_array($query);

echo"<tr>
<td width='119' class='Style5'><div align='left'>Numérorrr Commande :</div></td>
<td colspan='2' class='Style5'>
<div align='left'>
<input type='text' name='numCde' size='10' value='$request[0]'/>
</div>
</td>

<td width='119' class='Style5'><div align='left'>Date Commande :</div></td>
<td colspan='2' class='Style5'>
<div align='left'>
<input type='text' name='dateCde' value='$request[1]'/>
</div>
</td>

<td width='127' class='Style5'><div align='left'>Etat Commande :</div></td>
<td width='506' colspan='2' class='Style5'>
<div align='left'>
<input type='text' name='etatCde' value='$request[2]'/>
</div>
</td>
</tr>";

}

2 réponses

IpIpIpIpOne
Messages postés
436
Date d'inscription
mercredi 18 février 2009
Statut
Membre
Dernière intervention
24 mai 2009
114
16 mars 2009 à 16:32
Ami Terrien, essaye peut-être de remplacer

is_string($_POST['CdeRech'])

par

!is_numeric($_POST['CdeRech'])
0
Alain_42
Messages postés
5358
Date d'inscription
dimanche 3 février 2008
Statut
Membre
Dernière intervention
13 février 2017
898
16 mars 2009 à 18:10
je fais une liste déroulante que me donne le choix entre une recherche par numéro ou par fournisseur. selon le cas choisis j'affiche dans une liste déroulante, sur la page appelé dans mon action, soit tout les numéro de commande soit le nom de tout les fournisseur


Beaucoup plus simple et sur, si tu mets en champ caché lors de l'affichage de la page deuxième liste si c'est un num ou un fournisseur, car selon le navigateur ce n'est pas sur qu'un nombre ne soit pas renvoyé sous forme de string


en fct choix liste première page tu mets:
<imput type="hidden" name="recherche_par" value="num">

ou

<imput type="hidden" name="recherche_par" value="fourrnisseur">

et ensuite tu récupéreras $_POST['recherche_par']
0
zeOoo
Messages postés
29
Date d'inscription
vendredi 20 février 2009
Statut
Membre
Dernière intervention
14 juin 2009

17 mars 2009 à 11:09
je te remercie sa marche nikel ske tu ma di
0