Zet eerst het statement wel in een variabele en dan doe ik het alsnog met blokken.quote:Op dinsdag 3 juni 2014 15:24 schreef totalvamp het volgende:
[..]
Ik snap je haha, ik probeer ook altijd alles duidelijk te maken op die manier. Je zal dit iig nooit meer fout doen
Dat is ook nog een optie, alleen eigenlijk niet nodig voor deze lijn code.quote:Op dinsdag 3 juni 2014 15:26 schreef n8n het volgende:
[..]
Zet eerst het statement wel in een variabele en dan doe ik het alsnog met blokken.
quote:Op dinsdag 3 juni 2014 15:24 schreef slacker_nl het volgende:
http://blogs.atlassian.co(...)ck-ass-code-reviews/
Dan is sprintf een betere in sommige gevallen:quote:Op dinsdag 3 juni 2014 15:23 schreef n8n het volgende:
[..]
Oops ja sorry Ben 'gewend' dat code over meerdere regels kan en hou niet van lange regels dus ik zet grote statements vaak in blokken.
Bedankt allemaal ben blij dat het zo simpel was maar moet het maar net weten
1 2 3 4 5 6 7 8 9 | <?php $pdo = new PDO( sprintf('mysql:host=%s;dbname=%s', setup::database('host'), setup::database('name') ), setup::database('user'), setup::database('password') ); ?> |
Ik vind het vooral moelijk lelijk als de open- en sluit curlybrace niet op dezelfde indent staan. En ook als er na een sluitende curlybrace direct een nieuw statement komt zonder newline.quote:Op dinsdag 3 juni 2014 15:04 schreef Sitethief het volgende:
Ben ik echt de enige die dit doet?
[ code verwijderd ]
Ik vind het echt raar dat de curly brace die een if statement afsluit niet inspringt en de break die een case afsluit wel, ik vind dat zo onoverzichtelijk, bij mij zitten case en break op dezelfde diepte. Ik merk dat ik de enige ben die dit doet..
quote:Op dinsdag 3 juni 2014 15:30 schreef Aether het volgende:
[..]
Dan is sprintf een betere in sommige gevallen:
[ code verwijderd ]
Ik vind het alleen maar onduidelijker, daarnaast gebruik je een extra functie die eigenlijk niet nodig hoort te zijnquote:Op dinsdag 3 juni 2014 15:30 schreef Aether het volgende:
[..]
Dan is sprintf een betere in sommige gevallen:
[ code verwijderd ]
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | <?php class database { public static function connect() { try { $pdo = new PDO(' mysql:host='. setup::database('host') . ';dbname='. setup::database('name'), setup::database('user'), setup::database('password') ); } catch(PDOException $error) { print 'Error: ' . $error->getMessage(); die(); } } } |
Ja klopt, hahaha, maar heb een oplossing.quote:Op dinsdag 3 juni 2014 14:09 schreef Aether het volgende:
[..]
[ code verwijderd ]
Edit: je bedoelt dus iets anders.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | <?php function fetch_object($query, $id) { foreach($this->properties as $val => $key) { $holder[$key] = ''; $reference_properties[$key] =& $holder[$key]; } $mysqli = base::open_connection(); $stmt = $mysqli->prepare($query); $id = $id; $stmt->bind_param("i", $id); call_user_func_array(array($stmt, 'bind_result'), $reference_properties); $stmt->execute(); $stmt->fetch(); $stmt->close(); $mysqli->close(); foreach($reference_properties as $key => $val) $this->{$key} = $val; return $this; } ?> |
die werkt ook niet, heb van alles geprobeerd nu, probleem is dat er ; en , in zitten met andere functies dan php verwacht. Beetje vreemd allemaal maar het zal wel, vind de sprintf nu wel oké, wordt toch een basale website dus niet alles hoeft optimaalquote:Op dinsdag 3 juni 2014 15:35 schreef totalvamp het volgende:
[..]
Ik vind het alleen maar onduidelijker, daarnaast gebruik je een extra functie die eigenlijk niet nodig hoort te zijn
Als je het dan op meerdere lijnen wilt doen, doe het dan zo:
[ code verwijderd ]
Je kunt bij een variabele wel op een nieuwe lijn springen aangezien hij dit niet ziet als string.
Je gebruikt een functie die er niet hoort te zijn? Je bent bezig met een string maken, wat is er mis met sprintf ? (ik ben groot voorstander van sprintf en tegen $x . 'iets' . $anders . "want" . $dit . '\' is echt ' . $kut;quote:Op dinsdag 3 juni 2014 15:35 schreef totalvamp het volgende:
[..]
Ik vind het alleen maar onduidelijker, daarnaast gebruik je een extra functie die eigenlijk niet nodig hoort te zijn
Als je het dan op meerdere lijnen wilt doen, doe het dan zo:
[ code verwijderd ]
Je kunt bij een variabele wel op een nieuwe lijn springen aangezien hij dit niet ziet als string.
sprintf maakt het er namelijk niet duidelijker op, niet dat een concat wel duidelijk is.quote:Op dinsdag 3 juni 2014 17:25 schreef slacker_nl het volgende:
[..]
Je gebruikt een functie die er niet hoort te zijn? Je bent bezig met een string maken, wat is er mis met sprintf ? (ik ben groot voorstander van sprintf en tegen $x . 'iets' . $anders . "want" . $dit . '\' is echt ' . $kut;
Zo doe ik het over het algemeen ook, alleen bij de break; nog 1 extra tabjequote:Op dinsdag 3 juni 2014 15:04 schreef Sitethief het volgende:
Ben ik echt de enige die dit doet?
[ code verwijderd ]
Ik vind het echt raar dat de curly brace die een if statement afsluit niet inspringt en de break die een case afsluit wel, ik vind dat zo onoverzichtelijk, bij mij zitten case en break op dezelfde diepte. Ik merk dat ik de enige ben die dit doet..
HEREDOC is ook niet altijd wensenlijk en "" werkt ook niet altijd, want als je met class methods gebruikt wilt het wel/niet interpoleren. IiG, in perl doet dat het niet, ik vermoed dat PHP dat ook niet doet, met sprintf kan je duidelijk zien, wat je verwacht, floats, doubles, etc etc.quote:Op dinsdag 3 juni 2014 17:39 schreef totalvamp het volgende:
[..]
sprintf maakt het er namelijk niet duidelijker op, niet dat een concat wel duidelijk is.
Je kunt altijd nog de vars binnen de quotes plaatsen, al is dat niet overal even slim.
Ook kun je lange strings plaatsen in een HEREDOC om het echt overzichtelijk te houden.
Maar iedereen heeft zo zijn voorkeur natuurlijk.
Beste 2 manieren zijn trouwens HEREDOC en tussen dubble quotes ""
Dat gaat dus wel, sinds de latere PHP versies heb je daar ondersteuning in.quote:Op dinsdag 3 juni 2014 17:51 schreef slacker_nl het volgende:
[..]
HEREDOC is ook niet altijd wensenlijk en "" werkt ook niet altijd, want als je met class methods gebruikt wilt het wel/niet interpoleren. IiG, in perl doet dat het niet, ik vermoed dat PHP dat ook niet doet, met sprintf kan je duidelijk zien, wat je verwacht, floats, doubles, etc etc.
$x = <<OEF
DIt is een vet lange $persoon->id gaat volgens mij ook fout in een heredoc.
OEF
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | <?php /* More complex example, with variables. */ class foo { var $foo; var $bar; function foo() { $this->foo = 'Foo'; $this->bar = array('Bar1', 'Bar2', 'Bar3'); } } $foo = new foo(); $name = 'MyName'; echo <<<EOT My name is "$name". I am printing some $foo->foo. Now, I am printing some {$foo->bar[1]}. This should print a capital 'A': \x41 EOT; ?> |
Het is juist dat tabje wat ik zo raar vind .quote:Op dinsdag 3 juni 2014 17:44 schreef mstx het volgende:
[..]
Zo doe ik het over het algemeen ook, alleen bij de break; nog 1 extra tabje
het is toch een actie binnen de case, aan de andere kant lijkt het ook op een endif; dus beide moet wel kunnen. break zonder extra indent maakt het wel wat leesbaarder voor mij.quote:Op dinsdag 3 juni 2014 18:01 schreef Sitethief het volgende:
[..]
Het is juist dat tabje wat ik zo raar vind .
Dat snap ik echt niet. De break is onderdeel van de switch statement namelijk.quote:Op dinsdag 3 juni 2014 18:01 schreef Sitethief het volgende:
[..]
Het is juist dat tabje wat ik zo raar vind .
Hmm, wellicht is het handig om te beginnen met het leren van normaliseren van databases.quote:Op dinsdag 3 juni 2014 20:37 schreef djkoelkast het volgende:
Ik wil al een tijd een programma maken waarmee ik mijn videobanden kan indexeren.
Bandnummer, wat er op staat, bijzonderheden, opmerkingen en dus per programma een begintijd/eindtijd.
Ik ben er aan begonnen in het voor mij bekende Autoplay Media Studio. Dat werkt volgens Luascript en die database kan ik gebruiken via sqlite3, maar ik vind het maar heel erg ingewikkeld, vooral omdat er gewoon amper documentatie over is (omdat sqlite3 een 3rd party plugin is voor APMS). Ik kan alle data wel in de db krijgen, maar ik krijg het er niet meer uit
Enfin, het is niet meer dan een heleboel inputvelden, drop-downs, textfields en checkboxes eigenlijk en die moeten allemaal in een doorzoekbare database komen. Ik moet uiteindelijk op alles kunnen zoeken.
Dit kan natuurlijk ook gewoon in PHP/MySQL en volgens mij is dat A: makkelijker en B: is er veel meer documentatie over te vinden.
Ik heb wel wat html/php/mysql-kennis, maar ben wat dat betreft echt nog een beginner. Ik kan dingen aanpassen en meestal lukt dat ook wel, maar echt helemaal zelf hier dingen voor gaan schrijven is nieuw. Toch zou ik het willen proberen. Dan is het programma geen programma, maar een online database waarin ik:
Nieuwe records kan maken
Records kan bewerken
Zoeken in de records op alle mogelijke velden
Alle records weergeven in een lijst en die printbaar maken
Later:
Optie om geavanceerd te zoeken, bijvoorbeeld woord AAA maar alleen als bandtype B is.
Optie om andere databases (van andere mensen die hetzelfde gaan doen) te openen
Wellicht een optie om aan te klikken 'dit wil ik' en dat er dan een mailtje naar de recordhouder gaat.
Wachtwoord of liever beveiliging op accountniveau
Optie om een nieuwe database te beginnen
First things first:
Waar kan ik het beste beginnen, ik neem aan met het maken van een databaseconnectie en een database, maar dan. INSERT INTO ik ken het wel, maar ken de syntax niet. Zijn hier simpele voorbeelden van? Ook hoe ik meerdere velden in zo'n record maak.
Wat ik dus in 1 record zou willen hebben is:
Bandnummer
Systeem
Is de opname LP, Stereo, Slechte band, beschadigde band ofzo
Opmerkingenveld
En dan per tijdentry starttijd, eindtijd, omschrijving en een paar vinkjes zoals: compleet, komt onder een andere opname vandaan, gedigitaliseerd
Die tijdentries verschillen nogal, sommige banden heb je gewoon maar 1 ding op staan,
op een andere band kunnen wel 40 of 50 verschillende tijdentries staan. Dit moet dus ook voorzien zijn, dat je bijvoorbeeld 20 tijdentries op het scherm ziet en er met een knop meer bij kunt doen (of een volgende pagina begint, maar die eerste dingen van bandnummer tot opmerkingen blijven hetzelfde).
De primary key is dus eigenlijk het bandnummer.
Hellupie, hullepie
Die tab zorgt ervoor dat je alle case-statements op 1 lijn hebt en alle code die uitgevoerd wordt voor een case een niveau dieper. En je kunt ook meerdere case-statements hebben zonder break ertussen, dat is dan een reden voor een groter blok op de indent van de case:quote:Op dinsdag 3 juni 2014 18:01 schreef Sitethief het volgende:
[..]
Het is juist dat tabje wat ik zo raar vind .
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | <?php switch ($x) { case 1: case 3: case 5: echo '$x is oneven'; break; case 2: case 4: case 6: echo '$x is even'; break; default: echo 'Ik weet niet wat $x is'; break; } ?> |
Precies, zo vind ik het veel mooierquote:Op dinsdag 3 juni 2014 21:34 schreef Light het volgende:
[..]
Die tab zorgt ervoor dat je alle case-statements op 1 lijn hebt en alle code die uitgevoerd wordt voor een case een niveau dieper. En je kunt ook meerdere case-statements hebben zonder break ertussen, dat is dan een reden voor een groter blok op de indent van de case:
[ code verwijderd ]
Forum Opties | |
---|---|
Forumhop: | |
Hop naar: |