Wat bedoel je hiermee? Wat wil je precies dat er gebeurt?quote:Op woensdag 4 juni 2014 16:39 schreef n8n het volgende:
[..]
Was het er zelf ook al niet mee eens, wilde een manier vinden om objecten te kunnen extracten
dat als ik get::global('name') doe hij een object returned die $name heet. Leek me een manier om objecten door te sluizen maar ik ben er weer vanaf gestapt.quote:Op woensdag 4 juni 2014 17:18 schreef Tijn het volgende:
[..]
Wat bedoel je hiermee? Wat wil je precies dat er gebeurt?
Als je Composer installeert is autoloading echt een eitje.quote:Op woensdag 4 juni 2014 16:39 schreef n8n het volgende:
[..]
Was het er zelf ook al niet mee eens, wilde een manier vinden om objecten te kunnen extracten, dacht dat het zo kon. Dat het in elkaar stort bij wijziging is niet zo erg want het is ff snel hacken, ben al blij als iets werkt en ga het later nog een keer aanpassen allemaal zodra ik er wat meer van snap.
[..]
Ja moet daar nog kaas van zien te maken.
Heb het nu opgelost door m'n base.php content in index.php te zetten, alle variables zijn nu beschikbaar. Volgens mij kwam het omdat ik een require (navigation) deed binnen een file (base.php) die net daarvoor de andere files pas gedaan had. Kan nu weer ff verder, ga nu routes aanmaken en daarna de templates schrijven die op basis van de route ingevuld worden en dan ben ik er bijna aan de frontend. Daarna een 'CMS' maken zodat m'n vriendin zelfstandig de content kan uploaden.quote:Op woensdag 4 juni 2014 17:35 schreef Tijn het volgende:
Wat voor dingen zitten er in je setup object? Alleen properties of ook methods?
Sowieso begrijp ik je idee van "doorsluizen" niet eigenlijkIs het niet een idee om een static object te maken en met autoloaders te zorgen dat andere objecten erbij kunnen?
Dat heb ikquote:Op woensdag 4 juni 2014 17:58 schreef robin007bond het volgende:
[..]
Als je Composer installeert is autoloading echt een eitje.
Waarom niet gewoon constanten? Die zijn automatisch overal beschikbaar zonder dat je ze (per ongeluk) kunt veranderen.quote:Op woensdag 4 juni 2014 18:21 schreef n8n het volgende:
[..]
Edit: werkt toch niet, dan maar aan de autoloader ff proberen, de setup heeft alleen array's met config (beetje zoals WP het heeft)
1 2 3 4 5 6 7 8 | <?php function __autoload($class_name) { include $class_name . '.php'; } $obj = new MyClass1(); $obj2 = new MyClass2(); ?> |
Ik heb nu dat de class $database niet beschikbaar is in navigation.php (die included is in index.php). Snap er gewoon niks vanquote:Op woensdag 4 juni 2014 18:31 schreef Tijn het volgende:
[..]
Waarom niet gewoon constanten? Die zijn automatisch overal beschikbaar zonder dat je ze (per ongeluk) kunt veranderen.
Nee, dat zet je in een file die je inlaadt voordat je deze functionaliteit wilt gebruiken. Daarna "kent" je hele app de autoloader en kan-ie automatisch files includen op het moment dat je een class aanroept.quote:Op woensdag 4 juni 2014 18:31 schreef n8n het volgende:
[ code verwijderd ]
Hier staat dan (van php.net) een functie die een autoload doet, met dit moet je dan op elke pagina "__autoload($class_a);" zetten?
require 'setup.php'; $setup = new setup();quote:Op woensdag 4 juni 2014 18:33 schreef Tijn het volgende:
[..]
Nee, dat zet je in een file die je inlaadt voordat je deze functionaliteit wilt gebruiken. Daarna "kent" je hele app de autoloader en kan-ie automatisch files includen op het moment dat je een class aanroept.
Nou, dan is het super makkelijk te configureren. Check even de Composer site.quote:
Dat is de oude manier. De nieuwe manier gaat met spl_autoload_register.quote:Op woensdag 4 juni 2014 18:31 schreef n8n het volgende:
[ code verwijderd ]
Hier staat dan (van php.net) een functie die een autoload doet, met dit moet je dan op elke pagina "__autoload($class_a);" zetten?
En dat doet ie aan de hand van je....? set_include_path?quote:Op woensdag 4 juni 2014 18:33 schreef Tijn het volgende:
[..]
Nee, dat zet je in een file die je inlaadt voordat je deze functionaliteit wilt gebruiken. Daarna "kent" je hele app de autoloader en kan-ie automatisch files includen op het moment dat je een class aanroept.
quote:Op woensdag 4 juni 2014 19:16 schreef robin007bond het volgende:
[..]
Nou, dan is het super makkelijk te configureren. Check even de Composer site.
[..]
Dat is de oude manier. De nieuwe manier gaat met spl_autoload_register.
Maar ik raad je aan om Composer een autoloader te laten genereren. Veel makkelijker.
1 2 3 4 5 6 | <?php function __autoload($classname) { $filename = "classes/". strtolower($classname) .".class.php"; require($filename); } ?> |
Oo waarom niet?quote:Op woensdag 4 juni 2014 19:37 schreef robin007bond het volgende:
[..]
Tsja, maar dan heb je je project niet aan de PSR-standaarden.
en om aan te roepen build je een object met $var = new classname(); ?quote:
Ja, bijvoorbeeldquote:Op woensdag 4 juni 2014 20:03 schreef n8n het volgende:
[..]
en om aan te roepen build je een object met $var = new classname(); ?
1 2 3 | <?php $user = new User(); ?> |
ga ik even uitzoeken dan. Dacht dat je op een package doelde.quote:Op woensdag 4 juni 2014 19:16 schreef robin007bond het volgende:
[..]
Nou, dan is het super makkelijk te configureren. Check even de Composer site.
[..]
Dat is de oude manier. De nieuwe manier gaat met spl_autoload_register.
Maar ik raad je aan om Composer een autoloader te laten genereren. Veel makkelijker.
en met deze functie moet de naam van het bestand de naam van de class zijn (dus in principe 1 class per file wat ik al heb).quote:Op woensdag 4 juni 2014 20:06 schreef esv7 het volgende:
[..]
Ja, bijvoorbeeld
[ code verwijderd ]
, zolang ik de class User in de map classes heb staan.
Bij mij is het zo dat de controller functies uit het model gebruikt, en alleen in het model is er communicatie met de database.quote:Op woensdag 4 juni 2014 20:07 schreef n8n het volgende:
[..]
ga ik even uitzoeken dan. Dacht dat je op een package doelde.
Heb nu-denk ik-wel laravel meer door en het hele mvc gebeuren meer door. Voel me een stukje verzekerden dat het wel gaat lukken als ik het oppak.
Met de controller spreek je met de database, met de route bepaal je de views per url en de views zijn templates. Klopt dat een beetje in een nutshell?
dus controller geeft instructie aan de model en krijgt een object of boolean terug waarmee een actie voltooit wordt.quote:Op woensdag 4 juni 2014 20:09 schreef esv7 het volgende:
[..]
Bij mij is het zo dat de controller functies uit het model gebruikt, en alleen in het model is er communicatie met de database.
Ik heb de autoloader in mijn boot.php, dus ik hoef in geen van mijn controllers classes te includen.
Ik heb geen ervaring met Laravel, maar in de klassieke MVC-opzet heb je een model dat zorgt voor een representatie van je data. Daar heb je meestal het database-gebeuren in (in het geval dat die data in een database staat natuurlijk), niet in de controller.quote:Op woensdag 4 juni 2014 20:07 schreef n8n het volgende:
[..]
Met de controller spreek je met de database, met de route bepaal je de views per url en de views zijn templates. Klopt dat een beetje in een nutshell?
Arrays worden in PHP ook veel gebruikt.quote:Op woensdag 4 juni 2014 20:12 schreef n8n het volgende:
[..]
dus controller geeft instructie aan de model en krijgt een object of boolean terug waarmee een actie voltooit wordt.
Bij mij maak ik aan de hand van een class(model) een object(controller), vervolgens roep ik met dat object een method aan uit de class waarvan deze gemaakt is.quote:Op woensdag 4 juni 2014 20:12 schreef n8n het volgende:
[..]
dus controller geeft instructie aan de model en krijgt een object of boolean terug waarmee een actie voltooit wordt.
dat probeer ik nu een beetje te doen, mis dus nog een controller want dat doe ik nu in de templates (wat tegen het hele idee in gaat).quote:Op woensdag 4 juni 2014 20:12 schreef Tijn het volgende:
[..]
Ik heb geen ervaring met Laravel, maar in de klassieke MVC-opzet heb je een model dat zorgt voor een representatie van je data. Daar heb je meestal het database-gebeuren in (in het geval dat die data in een database staat natuurlijk), niet in de controller.
Het idee van de meeste frameworks is dat een router ervoor zorgt dat op basis van de url de juiste controllerfunctie wordt aangeroepen. In de controllerfunctie wordt dan data verzameld met behulp van een of meerdere models en uiteindelijk wordt een view aangeroepen waarin de HTML zit die je op de pagina wilt tonen.
Sommige simpele dingen kunnen wel in een template. Maar zodra er iets met je data moet gebeuren dat verder gaat dan een simpel regeltje, zou ik het verplaatsen naar de controller. Je wilt je templates qua programmeerwerk zo simpel mogelijk houden.quote:Op woensdag 4 juni 2014 20:14 schreef n8n het volgende:
[..]
dat probeer ik nu een beetje te doen, mis dus nog een controller want dat doe ik nu in de templates (wat tegen het hele idee in gaat).
als leek vind ik het trouwens raar dat db queries er anders zijn dan array 'queries' terwijl beide een soort tabel met data zijn.quote:
Wat?quote:Op woensdag 4 juni 2014 20:16 schreef n8n het volgende:
[..]
als leek vind ik het trouwens raar dat db queries er anders zijn dan array 'queries' terwijl beide een soort tabel met data zijn.
Forum Opties | |
---|---|
Forumhop: | |
Hop naar: |