Diskuze: OOP - pochopení logiky
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 8 zpráv z 8.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Ano máš pravdu, tímto příkazem skutečně uložíš hodnotu argumentu $jmeno do třídní proměnné $jmeno. Důležité tam je to $this, tím specifikujes že chceš přiřazovat do třídní proměnné, protože jinak má argument metody se stejným názvem větší prioritu.
public function __construct($jmeno,$prijmeni,$vek){
$this->jmeno=$jmeno;
$this->prijmeni=$prijmeni;
$this->vek=$vek;
}
Takže pokuď budu vytvářet instanci třídy
$salieri = new Clovek("Jarmil","Vomáčka","26");
Tak se mi uloží informace díky tomu? Děkuju předem za odpověd
$this->jmeno=$jmeno;
$this->prijmeni=$prijmeni;
$this->vek=$vek;
Ja bych to takto nedelal.
Bud bych si udelal strukturu nebo pouzil pole. Ale funkce bych mel zvlast. abys
tu strukturu mohl ulozit pak jako celek.
$data = array('jmeno' => $jmeno);
$this->data = $data;
echo json_encode($data); // kdyz cely balicek potrebujes predavat dal, napriklad pro web-services, jako json nebo xml a pod
Jinak
class Clovek{
// definice atributu
public $jmeno;
public $prijmeni;
public $vek;
private $unava = 0;
// definice metod
public function pozdrav(){
echo "Ahoj já jsem ".$this->jmeno;
}
// definice konstruktoru
public function __construct($jmeno1, $prijmeni2, $vek3){ // neni nutne receno, ze se to musi jmenovat stejne
$this->jmeno = $jmeno1;
$this->prijmeni = $prijmeni2;
$this->vek = $vek3;
$jmeno = 123; // je vnitrni promena platna jen v te funkci, tim $this to predavas prave do class
}
Viz, co sem psal na zacatku, ja bych to resil takto:
class Clovek{
// definice atributu
public $jmeno;
public $prijmeni;
public $vek;
public $unava;
}
//---
class funkceClovek{
public $data;
public function pozdrav(){
echo "Ahoj já jsem ".$this->jmeno;
}
// definice konstruktoru
public function __construct($jmeno1, $prijmeni2, $vek3){ // neni nutne receno, ze se to musi jmenovat stejne
// nebo bych mozna nechal construct v tom Clovek
$clovek = new Clovek();
$clovek->jmeno = $jmeno1;
$clovek->prijmeni = $prijmeni2;
$clovek->vek = $vek3;
$this->data = array();
$this->data['clovek'] = $clovek;
// nebo
$clovek = array(
'jmeno' => $jmeno1,
'prijmeni' => $prijmeni2
);
$this->data['clovek'] = $clovek;
}
Ja vim, ja vim, kdyz tam potrebujes private a jine zmeny, tak to tak nejde. Ale, kdyz mas ciste data, tak je lepsi je drzet spis ve strukture podobne databazi. Kdyz udelas ted 1000x new Clovek, tak v pameti ti to zabere mene nez kdyz se do kazdeho new Clovek musi pridat i ty funkce construct a pod. A taky, kdyz to budes chtit jsonovat nebo neco, tak je lepsi mit data, co jsonujes, pohromade. Takhle bys treba musel vybirat, ze 'unavu' tam nechces. Kdyz ji tam nechces, tak bych to uz na zacatku vyclenil.
class Clovek{
// definice atributu
public $a;
public $b;
public $c;
public function __construct($jmeno, $prijmeni, $vek){
$this->a = array();
$this->a['jmeno'] = $jmeno;
$this->a['prijmeni'] = $prijmeni;
$this->a['vek'] = $vek;
$this->b = array();
$this->b['unava'] = 0;
}
}
Ale, to je jen navrh. Samozrejme na nejaky skolni priklad o 10 polozkach je to jedno, asi. Kdyz tam mate takhle pouzivas class. Ja to samozrejme tak, jak to mas ty, pouzivam taky. Ale data vetsinou drzim zvlast, v app class, treba.
WTF co to je za odpověď? To je nesouvisející, nevyžádané a zbytečné.
Ano, díky tomuto:
$this->jmeno=$jmeno;
$this->prijmeni=$prijmeni;
$this->vek=$vek;
budeš mít ty data ("Jarmil","Vomáčka","26") v:
public $jmeno;
public $prijmeni;
public $vek;
po vytvoření instance.
Přesne tohle jsem chtěl slyšet.
Děkuji za vyřešení.
Já už začal,aby jste me lepe chapali.
Ahoj
Co je to za ptakovinu
Ale, kdyz mas ciste data, tak je lepsi je drzet spis ve strukture podobne databazi. Kdyz udelas ted 1000x new Clovek, tak v pameti ti to zabere mene nez kdyz se do kazdeho new Clovek musi pridat i ty funkce construct a pod.
V kazdem OOP by to melo zabirat stejne mista. Construktor a funkce jsou vzdy
vytvoreny jen jednou. Pokud je to v PHP jinak ???
tak se teda omlouvam
Zobrazeno 8 zpráv z 8.