Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP] pobieranie danych wewnątrz klasy
Forum PHP.pl > Forum > Przedszkole
piraciq
Witam serdecznie

mam taki problem:

prosta klasa do weryfikacji modułów taki schemat

1 pytam bazę po id czy dany moduł jest w bazie
2 sprawdzam czy istnieje
2.a jeśli tak chciałbym pobrać jego nazwę
2.b jeśli nie no to wyjątkiem go :]

jak to rozwiązać abym mógł tego użyć na zasadzie:
  1. <?php
  2. $mod=new mod();
  3. $mod->validModName('mod');
  4. $mod->getModName('mod');
  5. ?>

pozdrawiam
blooregard
W uproszczeniu:

  1. <?php
  2. class mod {
  3.  
  4. private $module;
  5. private $error;
  6.  
  7. public function validModName($mod) {
  8. try{
  9.    //sprawdzenie
  10.    //jesli w bazie istnieje, to
  11.    $this->module = $mod;
  12.  return true;
  13. //jesli nie, to
  14.  throw new exception( nie ma );
  15. } catch (Exception e) {
  16.    $this->error = $e->getMessage();
  17. }
  18.  
  19. public function showError() {
  20.   echo $this->error;
  21. }
  22. }
  23.  
  24.  
  25. public function getModName() {
  26. //wyciagniecie z bazy po $this->module
  27.   return wynik_wyciagniecia_z_bazy
  28. }
  29.  
  30.  
  31. }//class
  32.  
  33. $mod=new mod();
  34. $result = $mod->validModName('mod');
  35. if ($result) {
  36.   $mod->getModName();
  37. } else {
  38.   $mod->showError()
  39. ?>


...czy jakos tak. smile.gif
piraciq
ujmę to tak mam coś takiego
  1. <?php
  2. class modules
  3. {
  4.    protected $pdo;
  5.    public function __construct(PDO $pdo)
  6.    {
  7.        $this->pdo=$pdo;
  8.    }
  9.    
  10.    
  11.        private function validateMod($name)
  12.    {
  13.        $sql=$this->pdo->prepare("select * from modules where mod_name=:name limit 1");
  14.        $sql->bindValue(':name',$name);
  15.        $sql->execute();
  16.        if($row=$sql->fetch())
  17.        {
  18.            return true;
  19.        }
  20.        else
  21.        {
  22.            return false;
  23.        }
  24.    }
  25.           public function validateModName($id)
  26.    {
  27.        return $this->validateMod($id);    
  28.    }
  29. /// i teraz jak takie coś zrobić
  30. public function getModName($id)
  31. {
  32. //abym nie musiał wykonywać ponownie zapytania z tego co mi świta to chyba muszę wyżej zwrócić  tablice questionmark.gif
  33. }
  34.  
  35. }
  36. ?>
blooregard
Musisz dodać właściwość w klasie, która będzie przechwowywać wynik zwrócony w metodzie validateMod().

Wtedy każda inna metoda w klasie będzie sobie mogła z tego wyniku korzystać odwołując sie do niego $this->nazwa_wlasciwosci;
piraciq
A czy mógł byś troszkę jaśniej jak to ugryźć questionmark.gif
blooregard
  1. <?php
  2. private $result;
  3.  
  4. ...
  5.  
  6.  
  7. private function validateMod($name)
  8.   {
  9.       $sql=$this->pdo->prepare("select * from modules where mod_name=:name limit 1");
  10.       $sql->bindValue(':name',$name);
  11.       $sql->execute();
  12.       if($row=$sql->fetch())
  13.       {
  14.           $this->result = $row;
  15.       }
  16.       else
  17.       {
  18.           $this->result =  false;
  19.       }
  20.   }
  21. ?>


A w tej drugiej metodzie:
  1. <?php
  2. public function getModName()
  3. {
  4.  return $this->result;
  5.  
  6. }
  7. ?>
piraciq
Oki fajnie działa dzięki
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.