Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> echo? return? podstawy
-Aklim...-
post
Post #1





Goście







Witam.
Mam sobie funkcję:
Kod
function nowe_pliki($ilosc_plikow)
{
    $path = "/var/www/html/pafiledb";
    $template = "{INFO} - <a title=\"{FULLFILENAME}\" class=\"link\" href=\"{FILELINK}\">{SHORTFILENAME}</a><br />";
    require $path. "/includes/mysql.php";
    $pafiledb_sql->connect($db);
    $config = $pafiledb_sql->query($db,"SELECT * FROM $db[prefix]_settings",1);
    {
  $result = $pafiledb_sql->query($db, "SELECT * FROM $db[prefix]_files ORDER BY file_time DESC LIMIT 0, $ilosc_plikow", 0);
  $info = "{DATE}";
  $text = "{NAME}";
    }
    $i = 1;
    while ($file = mysql_fetch_object($result))
    {
  $line = str_replace("{NUMBER}", $i, $template);
  $line = str_replace("{FILELINK}", "$config[3]/pafiledb.php?action=file&id=$file->file_id", $line);
  $fileline = str_replace("{NAME}", skracaj($file->file_name), $text);
  $infoline = str_replace("{DATE}", date("j.m.Y", $file->file_time), $info);
  $line = str_replace("{FULLFILENAME}", $file->file_name, $line);
  $line = str_replace("{SHORTFILENAME}", $fileline, $line);
  $line = str_replace("{INFO}", $infoline, $line);
  echo $line;
  $i++;
    }
}

Oraz deklaruję sposób odwołania do funkcji w szablonie (w szablonie [bok.tpl] wpisuję tylko {OSTATNIE_PLIKI}):
Kod
[...]
    $ilosc_plikow = "10";
    $template->set_file('bok', 'bok.tpl');
    $template->set_var(array(
  'OSTATNIE_PLIKI' => nowe_pliki($ilosc_plikow)));

I teraz efekty- kod (funkcja newfiles($show)) działa, ale wynik pojawia się w najmniej oczekiwanym miejscu strony, nie tam gdzie to wstawiłem w szablonie (czyli w akapicie, boczej częsci strony).
Użyłem więc return $line, zamiast echo $line i efektem było wyświetlanie wyniku funkcji w prawidłowym miescu, ale samo zadziałanie funkcji było nieprawidłowe, ponieważ wyświetlało tylko 1 najnowszy plik z pafiledb, a nie tyle ile zadeklarowałem w zmiennej $ilosc_plikow (czyli 10). Natomiast gdy wyrzuciłem return $line poza pętle while efektem było wyświetlanie w pożądanym miejscu 1 najstarszego pliku.
Ja oczywiście chciałbym (najprawdopodobniej z użyciem return, nie echo i możliwe, że z użyciem pętli for zamiast while [nie wiem jak- zgaduję i przypuszczam]) uzyskać efekt wyświetlania tylu plików ile zadeklaruję w tej zmiennej $ilosc_plikow i w miejscu takim, jakim już sobie wybiorę wstawienie tego {OSTATNIE_PLIKI} w szablonie bok.tpl.
Proszę o pomoc, bo sam sobie z tym nie radzę!
P.S wiem, że ten temat razi brakiem kompletnych podstaw i nie potrafię dobrze opisać problemu... nie wiem, czy ktoś go zrozumie i mi pomoże, ale mam nadzieję, że tak, bo męczę się z tym i googluję ponad 3 dni.
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
-Aklim...-
post
Post #2





Goście







kurcze... lama jestem. Mam 2 problemy i ten drugi najprawdopodobniej wynika z pierwszego choć nie wiem, a mianowcie:
1. nie wiem gdzie wstawić to do wyświetlania, bo dotychczas wyświetlałem w sposób:
  1. <?php
  2.  
  3. [...]
  4. $ilosc_plikow = &#092;"10\";
  5. $template->set_file('bok', 'bok.tpl');
  6. $template->set_var(array(
  7.  'OSTATNIE_PLIKI' => nowe_pliki($ilosc_plikow)));
  8.  
  9. ?>

i w pliku bok.tpl w wybranym miejscu wpisywałem tylko:
Kod
{OSTATNIE_PLIKI}

funkcją było to co podałem na początku, a teraz funkcja wygląda tak:
  1. <?php
  2.  
  3. function nowe_pliki($ilosc_plikow)
  4. {
  5. $path = &#092;"/var/www/html/pafiledb\";
  6. $tpl = &#092;"{INFO} - <a title=\"{FULLFILENAME}\" class=\"link\" href=\"{FILELINK}\">{SHORTFILENAME}</a><br />\";
  7. require $path. &#092;"/includes/mysql.php\";
  8. $pafiledb_sql->connect($db);
  9. $config = $pafiledb_sql->query($db,&#092;"SELECT * FROM $db[prefix]_settings\",1);
  10. {
  11. $result = $pafiledb_sql->query($db, &#092;"SELECT * FROM $db[prefix]_files ORDER BY file_time DESC LIMIT 0, $ilosc_pli
    kow\", 0);
  12. $info = &#092;"{DATE}\";
  13. $text = &#092;"{NAME}\";
  14. }
  15. $i = 1;
  16. while ($file = mysql_fetch_object($result))
  17. {
  18. $line = str_replace(&#092;"{NUMBER}\", $i, $tpl);
  19. $line = str_replace(&#092;"{FILELINK}\", \"$config[3]/pafiledb.php?action=file&id=$file->file_id\", $line);
  20. $fileline = str_replace(&#092;"{NAME}\", skracaj($file->file_name), $text);
  21. $infoline = str_replace(&#092;"{DATE}\", date(\"j.m.Y\", $file->file_time), $info);
  22. $line = str_replace(&#092;"{FULLFILENAME}\", $file->file_name, $line);
  23. $line = str_replace(&#092;"{SHORTFILENAME}\", $fileline, $line);
  24. $line = str_replace(&#092;"{INFO}\", $infoline, $line);
  25. $tab[$i] = $line;
  26. $i++;
  27. }
  28. return $tab;
  29. }
  30.  
  31. ?>

i samo to daje mi tylko wyświetlenie "Array", więc gdzieś muszę wpisać to
  1. <?php
  2. for ($i=1, $i<=count($tab);$i++) echo tab[$i];
  3. ?>

ale nie wiem gdzie - to pierwszy problem.
2. Gdziekolwiek nie próbowałem użyć tej pętli for z echo to parser wywalał
Kod
Parse error: parse error, unexpected ')', expecting ';' in /var/www/html/test/funkcje.php on line 466

Mam nadzieję, że wynika to z tego, że nie wiem gdzie to wstawić (choć próbowałem w różnych miejscach nawet z odrobiną logiki)...

Pomózcie... wiem, że to bezinteresowne i w ogóle mam zapewne lamerskie problemy, ale znam inne języki (taak... czytałem kursy, książki php itp.), a programista php/sql, który się tym zajmował wyparował i teraz ja muszę wszystko dokończyć :/ Radzę sobie powiem szczerz dobrze, ale tylko operując i modyfikując to co już on zrobił, a nie tworząc swoje (choć już pare rzeczy udało mi się stworzyć [edytor wysywig z bbcode (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) ]) jeszcze raz... help (IMG:http://forum.php.pl/style_emoticons/default/sadsmiley02.gif)
Go to the top of the page
+Quote Post

Posty w temacie
- Aklim...   echo? return? podstawy   26.06.2005, 01:51:45
- - Pigula   return zwraca ci wartosc i dlatego jak miales w pe...   26.06.2005, 09:23:07
- - Aklim...   Mniejwięcej rozumiem to co pisesz, ale wciąż nie w...   26.06.2005, 10:08:19
- - aleksander   @Aklim...:   26.06.2005, 10:35:15
- - Pigula   [PHP] pobierz, plaintext <?php $i = 1;while ...   26.06.2005, 10:40:32
- - Aklim...   kurcze... lama jestem. Mam 2 problemy i ten drugi ...   26.06.2005, 20:31:42
- - Pigula   bo pisalem z glowy i jest blad powinno byc tak: [...   27.06.2005, 08:06:51
- - Aklim...   RE: echo? return? podstawy   28.06.2005, 16:21:34
- - Aklim...   Kurcze, edytowac nie mogę. Nie ma odpowiedzi, czyl...   29.06.2005, 21:32:08


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 4.10.2025 - 14:22