PHP et POO: problème de débutant^^
Résolu
Smoking bird
Messages postés
870
Date d'inscription
Statut
Membre
Dernière intervention
-
Smoking bird Messages postés 870 Date d'inscription Statut Membre Dernière intervention -
Smoking bird Messages postés 870 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
Je code en php depuis quelques mois déjà, mais j'ai jamais réussi à convenablement me familiariser avec la POO. J'essais de me repencher sur la question, en adaptant cette méthode à la création d'un système de messages privés, mais mon code ne fonctionne pas. Quelqu'un pourrait il me dire où j'ai fauté?
class note {
public $titre;
public $statut;
public $date;
public $texte;
public $exp;
public $dest;
if($statut=="nouveau")
{
?>
<li style="background-color:teal"><?php echo $this->titre; echo $this->date; echo $this->exp; ?></li>
<?php
}else{
?>
<li><?php echo $this->titre; echo $this->date; echo $this->exp; ?></li>
<?php
};
};//fin de la classe
$sql="SELECT * FROM box ";
$query=mysql_query($sql);
while($callNote=mysql_fetch_array($query))
{
$note=new note();
$note->exp=$callNote['exp'];
$note->dest=$callNote['dest'];
$note->date=$callNote['date'];
$note->titre=$callNote['titre'];
$note->statut=$callNote['statut'];
$note->texte=$callNote['texte'];
};
Je code en php depuis quelques mois déjà, mais j'ai jamais réussi à convenablement me familiariser avec la POO. J'essais de me repencher sur la question, en adaptant cette méthode à la création d'un système de messages privés, mais mon code ne fonctionne pas. Quelqu'un pourrait il me dire où j'ai fauté?
class note {
public $titre;
public $statut;
public $date;
public $texte;
public $exp;
public $dest;
if($statut=="nouveau")
{
?>
<li style="background-color:teal"><?php echo $this->titre; echo $this->date; echo $this->exp; ?></li>
<?php
}else{
?>
<li><?php echo $this->titre; echo $this->date; echo $this->exp; ?></li>
<?php
};
};//fin de la classe
$sql="SELECT * FROM box ";
$query=mysql_query($sql);
while($callNote=mysql_fetch_array($query))
{
$note=new note();
$note->exp=$callNote['exp'];
$note->dest=$callNote['dest'];
$note->date=$callNote['date'];
$note->titre=$callNote['titre'];
$note->statut=$callNote['statut'];
$note->texte=$callNote['texte'];
};
A voir également:
- PHP et POO: problème de débutant^^
- Easy php - Télécharger - Divers Web & Internet
- Expert php pinterest - Télécharger - Langages
- Retour a la ligne php - Forum Webmastering
- Super poo - Forum Programmation
- Alert php - Forum PHP
7 réponses
salut,
je vais pas te répondre complètement.
ta classe est un bout de code indépendant du reste et qui sert principalement à effectuer des taches répétitives.
c'est le gabarit de ton objet.
un objet à des propriétés et des méthodes que tu appelleras d'un autre script.
les propriétés, mieux vaut les garder "private" et les lire/écrire avec les méthodes ad-hoc 'getPropriete()', 'setPropriete( $value )'.
dans ton cas, le plus simple est d'attribuer toutes les valeurs des propriétés en les passant au constructeur (c'est la méthode utilisée par 'new').
ensuite tu appelles une méthode de ta classe qui enverra les infos sous forme de HTML.
je suppose que tu vas être un peu perdu avec ce que je t'écris, regarde le source suivant et dis moi si tu t'y retrouves.
je vais pas te répondre complètement.
ta classe est un bout de code indépendant du reste et qui sert principalement à effectuer des taches répétitives.
c'est le gabarit de ton objet.
un objet à des propriétés et des méthodes que tu appelleras d'un autre script.
les propriétés, mieux vaut les garder "private" et les lire/écrire avec les méthodes ad-hoc 'getPropriete()', 'setPropriete( $value )'.
dans ton cas, le plus simple est d'attribuer toutes les valeurs des propriétés en les passant au constructeur (c'est la méthode utilisée par 'new').
ensuite tu appelles une méthode de ta classe qui enverra les infos sous forme de HTML.
je suppose que tu vas être un peu perdu avec ce que je t'écris, regarde le source suivant et dis moi si tu t'y retrouves.
<?php class note { private $titre; private $statut; private $date; private $texte; private $exp; private $dest; public function __construct( $titre , $statut , $date , $texte , $exp , $dest ) { $this->titre = $titre; $this->statut = $statut; $this->date = $date; $this->texte = $texte; $this->exp = $exp; $this->dest = $dest; } public function output() { if( $this->statut === 'nouveau' ) { echo '<li>'.$this->titre.' '.$this->date.' '.$this->exp.' '.'</li>'; } else { echo '<li style="background-color:teal">'.$this->titre.' '.$this->date.' '.$this->exp.' '.'</li>'; } } } ?> <?php // AUTRE SCRIPT $sql="SELECT * FROM box "; $query=mysql_query($sql); while($callNote=mysql_fetch_array($query)) { $note = new note( $callNote['titre'] , $callNote['statut'] , $callNote['date'] , $callNote['texte'] , $callNote['exp'] , $callNote['dest'] ); $note->output(); }
oki.
au passage, j'ai retrouvé ce tuto, c'est pour PHP4 mais les bases sont là.
au fait, es-tu passé à PHP5 ?
au passage, j'ai retrouvé ce tuto, c'est pour PHP4 mais les bases sont là.
au fait, es-tu passé à PHP5 ?
J'y suis passé oui^^ et j'ai l'impression que l'envoi de ma dernière réponse a zappé les remerciements^^ alors je réitère, merci pour les explications :D le coup de main, et le tuto ;) :) et en parlant de ce dernier, j'ai un bouquin sur php5, c'est avec lui que j'ai appris, mais la section POO est plutôt obscure. Ceci dit, le tuto combiné au bouquin devrait pouvoir me permettre de bien intégrer tout ça ;)
Cheers!
Cheers!
oki !
tiens nous informés stp et ferme le fil si tu t'y retrouves !
-;o)
à plus tard et bon courage pour la suite !
tiens nous informés stp et ferme le fil si tu t'y retrouves !
-;o)
à plus tard et bon courage pour la suite !
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Problème résolu, m'suis mis à la POO comme un fou^^ mon petit système de messagerie privé permet même une actualisation en direct via Ajax, ça fonctionne super bien ;)
Merci encore et à plus :)
Merci encore et à plus :)
Le code ne me paraît pas trop hermétique :) ;) j'devrais m'y retrouver quand je pourrais m'y pencher un peu plus sérieusement^^ en tous les cas, merci pour les explications et la modification :)