Suite à un billet d’un collègue développeur (Jarodxxx), et d’un commentaire souhaitant obtenir un return, je vous propose quelques fonctions très utiles que j’utilise.
1 - Fonction qui retourne une liste déroulante (SELECT, ComboBox) :
-
/*fonction qui fabrique une combobox
-
parametres :
-
$tabs => $tableau qui contient les données a mettre dans la combo
-
$value => champ utiliser comme value
-
$text => champ a utiliser comme text
-
$comboname => nom a donner a la combo
-
$inserblank => boolean qui dit si on doit inserer une ligne blanche au debut de la combo
-
$selectedValue => valeur a selectionner dans la combo
-
$onChangeEvent => fonction javascript a appeler sur l’event ‘onChange’
-
$disabled => desactiver ou non la liste*/
-
-
function makeComboBox($tabs, $value, $text, $comboname, $insertblank=false, $selectedValue=false, $onChangeEvent=”, $disabled=false)
-
{
-
/*par defaut, combo "vide" */
-
$return = ‘<select name="’.$comboname.‘" id="’.$comboname.‘" disabled="disabled"><option value="">Empty list</option></select>’;
-
-
{
-
$return = ‘<select name="’.$comboname.‘" id="’.$comboname.‘"’;
-
if ($onChangeEvent != ”)
-
$return .= ‘ onChange="’.$onChangeEvent.‘"’;
-
if ($disabled)
-
$return .= ‘ disabled="disabled"’;
-
$return .= ‘>’;
-
-
if ($insertblank)
-
$return .= ‘<option value=""></option>’;
-
-
foreach($tabs as $tab){
-
//for ($i=0; $i<count($tab); $i++){
-
-
$return .= ‘<option value="’.$tab[$value].‘"’;
-
if ($selectedValue!=false)
-
if ($tab[$value] == $selectedValue)
-
$return .= ‘ selected="selected"’;
-
$return .= ‘>’.$tab[$text].‘</option>’."\n";
-
}
-
$return .= ‘</select>’;
-
}
-
return $return;
-
}
-
2 - Fonction qui retourne un Multi Select : Liste déroulante avec plusieurs choix possibles:
-
/*Gestion des combos a selection multiples
-
parametres :
-
$tab => $tableau qui contient les données a mettre dans la combo
-
$value => champ utiliser comme value
-
$text => champ a utiliser comme text
-
$comboname => nom a donner a la combo
-
$inserblank => boolean qui dit si on doit inserer une ligne blanche au debut de la combo
-
$selectedValue => valeur a selectionner dans la combo
-
$onChangeEvent => fonction javascript a appeler sur l’event ‘onChange’
-
$disabled => desactiver ou non la liste
-
$size => Nombre d’élément de la liste que l’on affiche
-
*/
-
function makeMultipleComboBox($tab, $value, $text, $comboname, $insertblank=false, $selectedValue, $onChangeEvent=”, $disabled=false, $size=5)
-
{
-
/*on recupere une combo normale, sans rien selectionner*/
-
$return = $this->makeComboBox($tab, $value, $text, $comboname, $insertblank, -1, $onChangeEvent, $disabled);
-
/*On change le type de combo*/
-
$return =
str_replace(‘<select ‘,
‘<select multiple size="’.
$size.
‘" ‘,
$return);
-
/*on parse le code html pour rajouter les selections la ou il faut*/
-
if (!
empty($selectedValue))
-
{
-
//print_r($selectedValue);exit;
-
//$tSelectedValue = split(’,', $selectedValue);
-
foreach ($selectedValue as $cur)
-
{
-
$return =
str_replace(‘<option value="’.
$cur.
‘">’,
‘<option value="’.
$cur.
‘" selected="selected">’,
$return);
-
}
-
}
-
return $return;
-
}
-
2 fonctions très utiles donc qui génèrent le code HTML.
Voici un code pour alterner le contenu de 2 DIV et avec un seul lien.
On va créer tout d’abord 2 div contenant 2 textes à alterner avec un CSS element.style.display différent.
<div id=”mod_1″ style=”display: block;”> BONJOUR </div>
<div id=”mod_2″ style=”display: none;”> AU REVOIR </div>
Explication : element.style.display ne retourne une valeur que si l’élément a un attribut HTML style avec propriété CSS display renseignée, donc dans notre cas, la DIV avec l’id mod_1 sera affichée au chargement de la page tandis que mod_2 sera cachée.
Il nous faut un lien pour pouvoir alterner entre les 2 div.
<a onclick=”alterner(’mod_1′,’mod_2′);” title=”Alterner les 2 div”>Alterner</a>
Il nous manque plus que le Javascript :
<script type=”text/javascript”>
function alterner(obj1, obj2){
var obj1 = document.getElementById(obj1);
var obj2 = document.getElementById(obj2);
obj1.style.display = (obj1.style.display == “block”) ? “none” : “block”;
obj2.style.display = (obj2.style.display == “block”) ? “none” : “block”;
}
</script>
Que va faire le script ? Si la DIV mod_1 (obj1 la fonction javascript) est à display:block (affichée) alors on définit la DIV mod_2 à display:none (cachée) et inversement.
Voici un exemple en cliquant sur le lien “Alterner les DIV” :
Alterner les DIV
BONJOUR
AU REVOIR
Je commence à vous montrer quelques scripts et astuces pour améliorer vos codes (PHP).
Une petite astuce toute simple pour mettre des majuscules à tous vos mots d’une chaîne de caractères. La fonction ucwords(); de php le permet , exemple :
$chaine = ‘alexandre val developpeur web’;
echo ucwords($chaine);
Ce qui affichera :
Alexandre Val Developpeur Web
Attention : la fonction ne comprend pas les ‘-’, ‘_’ ‘(’ devant les lettres. ce qui fait qu’une phrase comme celle-ci :
echo ucwords(’alexandre val (developpeur web)’);
affichera :
Alexandre Val (developpeur Web)
N’oubliez pas les fonction pour tout réduire en minuscule : strtolower(); et en majuscule : strtoupper();
strtolower(), que l’on peut combiner avec ucwords() pour formatter le texte, exemple :
$chaine = ALEXANDRE VAL DEVELOPPEUR WEB’;
echo ucwords(strtolower($chaine));
Affichera :
Alexandre Val Developpeur Web
- Refonte graphique de mon site CV Freelance. Voir la précédente version.
- Développement d’une page de démarrage personnalisable.
Cliquez pour voir l’explication
- Administrateur du Site/Blog Tuxboard.com.
Plus de 30.000 visiteurs quotidien. Consultez les statistiques en détails de mon blog.
Design CSS, développement PHP/MySQL, retouche Photoshop et administration Linux (Debian).
Disponible à cette adresse.
- Développement du site Wanimo.com.
Design CSS, développement PHP(Objet)/MySQL, retouche Photoshop.
Disponible à cette adresse.
- Création du site Cronos.
Découpe Photoshop, intégration graphique, design CSS, développement PHP.
- Développement de modules pour un forum de poker : Lyonholdem.com
Création de module greffés au forum de discussion et au backoffice.
Disponible à cette adresse.
Vous pouvez tester l’application.
- Développement d’une boutique en ligne simplifiée (Paiement par Paypal/CB).
Possibilité d’upgrader en boutique en ligne avec paiement en ligne CB.
Disponible à cette adresse.
Vous pouvez tester l’application.
Création d’un système de cache en PHP orienté objet pour sites pour téléphone mobile.
Les fonds d’écran ont tous été créé sous Photoshop en 2004.