Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: Pager (stronicowanie)
Forum PHP.pl > Forum > Gotowe rozwiązania > Algorytmy, klasy, funkcje
Stron: 1, 2, 3, 4, 5
nospor
info
pobierz

Hejka, prezentuję klasę Pager. Umożliwia ona wygenerowanie pager'a oraz pobranie aktualnych indexów rekordów.

Użycie jest proste:

  1. <?php
  2.    $pager = new Pager('idPagera');
  3.    //okreslenie liczby wszystkich rekordów na 500
  4.    $pager->SetTotalRecords(500);
  5.    echo $pager->Render();//wyswietlenie pagera
  6. ?>


Polączenie pagera z pobieraniem rekordów z bazy:
  1. <?php
  2.    $sql = 'select count(*) from TABLE';
  3.    $result = mysql_query($sql);
  4.    $row = mysql_fetch_array($result);
  5.    $recordsCount = $row[0];//pobranie liczby rekordów
  6.    $pager = new Pager('idPagera');
  7.    $pager->SetTotalRecords($recordsCount);//ustawienie liczby rekordów
  8.    //wygenerowanie pagera i zapamietanie go w zmiennej w celu
  9.    //pozniejszego wyswietlenia
  10.    $renderPager = $pager->Render();
  11.    $start = $pager->GetIndexRecordStart();//pobranie indexu rekordu początkowego
  12.    $end = $pager->GetIndexRecordEnd();//pobranie indexu rekordu koncowego
  13.    //zapytanie z uwzglenieniem stronicowania
  14.    $sql = 'select * from TABLE limit '.$start.','.($end - $start + 1);
  15.    //...pobranie wyników i ich wyswietlenie
  16.    echo $renderPager; //wyswietlenie pager'a
  17. ?>

(edit: te przyklady od wersji 2.5 troche inaczej beda wygladac. poprawne kody w paczce)

W podanym przykladzie brakuje oczywiscie sprawdzania, czy dane zapytanie wykonalo sie poprawnie itp. Nie podawałem tego jednak po to, by nie zaciemniać kodu.


Klasa generuje unikalne dla każdego pagera (poprzez idPager'a) zmienne, dzięki czemu na stronie może byc kilka pagerów do różnych tabel. Dodatkow, jesli korzystacie z sesji, klasa pamieta strony w sesji, dzięki czemu nie tracone są informacje o aktualnej stronie przy odwiedzaniu innych linków


Klasa ma 3 sposoby przechodzenia do kolejnych stron:
1) generuje własny wewnetrzny formularz i go submituje
Konstruktor tylko z pierwszym argumentem
2) korzysta z zewnetrznego formularza i musi byc w nim zawarta
Konstruktor z pierwszym i trzecim argumentem. Jako trzeci argument należy podać
idFormularza zawnętrznego
3) poprzez linki. Należy wówczas określić drugi parametr w konstruktorze, który będzie linkiem podstawowym. Do niego dodany będzie parametr odnosnie strony. Ten sposób generuje ogólne zmienne dla pagera, przez co lepiej żeby dla niego na stronie byl tylko jeden pager. Sposób ten może być wykorzystywany przy wyszukiwarkach.

To chyba wszystko. Wszelkiego rodzaju uwagi, sugestie bądź wynalezione błędy proszę zgłaszać. Wysłucham każdej smile.gif

Aha, sposób implemetncji klasy dostosowany do php4. Klasa nie korzysta z żadnych dziwnych funkcji, więc można łatwo dostosować ją do php5. Należy tylko metody i zmienne deklarować w sposób odpowiedni dla php5.

Wszystkie metody i zmienne zaczynajace się na podkreslenie (_) oznaczają, iż są to metody i zmienne prywatne.

A oto przykladowy widok pager'a:
Cytat
|<  <<  <  21  22  23  24  25  26  27  28  29  30  z 200  >  >>  >|

oczywiscie wszystko to linki oprócz aktualnej strony.

Pager jest łatwo konfigurowalny. MOżecie sami okreslic liczbe rekordów na stronie, liczbę stron w pagerze itp.

A pozatym niech wam dobrze służy smile.gif

edit (2006-04-03)
W związku z licznymi uwagami, by klasa nie generowala linkow co x, tylko pare linków przed stroną i parę linków po, wprowadzilem lekkie modyfikacje. Sposób uzywania klasy nie uległ zmianie (jest kompatybilna wstecz smile.gif ). Chcąc użyc nowej metody generowania linków, wystarczy wywołać metodę render() z parametrem true:
  1. <?php
  2. echo $pager->Render(true);
  3. ?>

Mam nadzieję, że w ten sposób usatysfakcjonowałem parę osób winksmiley.jpg

edit (2006-06-13)
Dawno nic nie pisalem. Czas zmienic. A wiec jest wersja 2.0
Główne zmiany:
1) odejscie od przesylania pagera formularzem
2) zapisywanie Pagera do tablicy, z której mozna samemu wygenerowac kod html Pager'a
3) PLucie wyjatkami smile.gif
4) no i obecna wersja jest pod php5. Niedlugo dorobie tez wersje pod php4.

Zapraszam do sciagania i testowania.
W paczce jest kilka przykaldow, min. jak nalezy doczepic generowanie wlasnego kodu html.

Jesli zrobicie swoja funkcje generujaca kod html i bedziecie chcieli sie nia podzielic, wyslijcie mi a ja upublikuje wersje demo z wasza funkcja i wygladem pagera.

edit: 2.0 jest juz i pod php4

edit (2006-08-22)
Wersja 2.01:
- dorobilem na szybko ten link. teraz w konstruktorze, jesli podamy drugi parametr i bedzie w nim ciag:
#PAGE# to link ten zostanie niezmieniony, czyli bedzie tak jak user podal, za wyjatkiem #PAGE#, ktore zostanie zamienione na numer strony
Czyli dla przykladu co podal AxZx powinno byc:
  1. <?php
  2. $pager = new Pager('idPagera', 'wszystkie_numery_#PAGE#');
  3. ?>


- metoda Render moze zwracac teraz tablicę pagera zamiast kodu html. Należy ustawic na true jej trzeci parametr

edit (2007-07-26)
Wersja 2.5. Więcej info tu: http://nospor.pl/pager-2.5.html
Bakus
Rozwiązanie bez wątpienia warte uwagi, ale po sesjach widać, że nie pracujesz na E_ALL - gdy nie zostanie wywołana sesja (session_start) wszelkie odwołania do $_SESSION będą powodować błąd E_NOTICE.
Poza tym powinieneś dać możliwość wyłączenia tej funkcji.

Poza tym co w przypoadku, gdy skrypt będzie działał przez mod_rewrite (np. na stronie: ./get-art-143.xml => ./index.php?act=get&co=art&id=143) przy założeniu, że JS został wyłączony?
nospor
@Bakus
Widzę że kod przeanalizowales dokladnie smile.gif. Dziękuję za zainteresowanie i cenne uwagi. Faktycznie, system obslugi bledów mam inny i E_NOTICE nie widze.
Problem z brakiem sesji juz rozwiązałem i przeedytowalem klasę.

Co do możliwości wyłączenia zapisu w sesji - już jest smile.gif

Co do js to zapomnialem dodać, iż jest wymagane smile.gif Oczywiscie w przypadku gdy pager korzystać będzie z formualrza. Gdy z linków to js nie jest potrzebne.

mod_rewrite: hmmm. Nie używalem Pagera do tego typu metod, wiec nie myslalem nad rozwiązaniem. Może w wolnej chwili.
Bakus
Przydał by się jeszcze jeden mały bajer: "połamanie linii"... by kod nie przenosił się do następnych linijek (powoduje to błędy w numerowaniu linii)
nospor
mówisz - masz smile.gif
Bakus
cudo biggrin.gif
Balas
Mam kod ktory pobiera dane z bazy mysql (w tablicy) i wyswietla (while), jak to podpiac do tego questionmark.gif snitch.gif
(jestem poczatkujacy i nie kumam ocb tongue.gif znaczy jakj to zrobic :])
NuLL
Masz wszystko przecież jak wół napisane.
AxZx
wydaje mi sie ze klasa generuje kod HTMl niezgodny ze standardem,

powinno byc &amp; zamiast &
nospor
@OnE.Killer odpowiedzialem tutaj:
http://forum.php.pl/index.php?act=ST&f=27&...t=0#entry202136

@AxZx hmm, szczerze powiedziawszy nie wiem czy to zgodne ze standardem czy nie. Ale to przecież zaden problem podmienić & na &amp; . Występuje to tylko w jednym miejscu (linia 114)
Ale dzięki za info smile.gif
AxZx
wiem ze mozna samemu sobie zmienic, ale czemu ty nie mozesz tego zrobic? zeby ten kto bedzie uzywal od razu mial gotowa elegancko klase w ktorej nic nie trzeba zmieniac:)
wiadomo - twoja wola.

a mam takie pytanie
czy nie lepiej by bylo gdyby np przy 10 podstronie widoczne byly linki do stron nastepnych i poprzednich?
np 5 poprzednich i 5 nastepnych, bo teraz jest tak ze jest 10 stron i koniec, tylko strzalki w prawo sa.
nospor
Cytat
wiem ze mozna samemu sobie zmienic, ale czemu ty nie mozesz tego zrobic? zeby ten kto bedzie uzywal od razu mial gotowa elegancko klase w ktorej nic nie trzeba zmieniac:)
wiadomo - twoja wola.
Dobra, zamieniam. Dzięki za cynk smile.gif

Cytat
a mam takie pytanie
czy nie lepiej by bylo gdyby np przy 10 podstronie widoczne byly linki do stron nastepnych i poprzednich?
np 5 poprzednich i 5 nastepnych, bo teraz jest tak ze jest 10 stron i koniec, tylko strzalki w prawo sa.
A tutaj to chyba cię nie rozumiem.
Są trzy rodzaje linków
<,> - poprzednia/nastepna strona
<<, >> poprzednie/nastepne dziesieć (liczbę tę można regulowac) to jest chyba to oco ci chodzi, czyli kolejne x stron
|<, >| pierwsza/ostatnia strona

Kazdy z tych linków sie pojawia, jezeli ma do czego przeniesc, jesli nie ma do czego przenieśc to sie nie pojawiają. Oto ci chodziło? Bo za bardzo nie widzę problemu w twoim przedstawieniu sprawy
AxZx
http://www.w3.org/

sprawdz strony z Twoim stronicowaniem w walidatorze, wyswirtli error w miejscu &


a co do linkow to chodzi mi o cyfry

teraz jest
Kod
|< << < 1 2 3 4 5 6 7 8 9 |10| > >> >|

gdzie |10| to aktualna strona

a ja zapytalem czy nie moze to sie przesuwac
np.
Kod
|< << < 5 6 7 8 9 |10| 11 12 13 14 15 > >> >|


moze takie cos juz jest ?
nospor
aha, już czaję o co ci chodzi. Chcesz by aktualna strona była po środu wyswietlanych. Nie, teraz tego nie ma. Leci pakietami czyli co 10 (domyślnie, można regulować dlugosc tego "pakietu" ). W sumie funkcjonalność ciekawa. Być może dorobie w wolnej chwili. Będzie wówczas się mówiło czy chce się tak, czy inaczej.
Dzięki za sugestie, jak pisałem mile widziane są smile.gif

Co do & to juz poprawiłem smile.gif.
AxZx
a jeszcze mam takie pytanie, chociaz nie wiem czy jest to mozliwe bo w swojej klasie nie udalo mi sie tego osiagnac

chodzi o mod_rewrite:)

jak juz ktos wspominal, czy daloby sie to zrobic?

mam np branza.1
i teraz chcialbym branza.1.1
branza.1.2
itd
to w czym to mam zrobic?
nospor
he? Czy Twoje pytanie ma związek z Pager'em? Bo ja ni w ząb nie kumam. Co to ma byc te branża.1, branza.1.1, branza.1.2 ?
AxZx
branza.1.2

1 to numer branzy
a 2 to numer strony:)

chcialbym aby wlasnie taki link generowal pager, i dlatego pytam sie czy da sie to jakos rozwiazac.
nospor
O, i nie można było tak od razu ? smile.gif
Teraz wszystko kumam smile.gif
Link da sie wygenerować po bardzo małej przeróbce. Gorzej z odebraniem danych z linku.
Teraz jestem dość mocno zajęty i nie mam czasu by pobawić sie mod rewrite. W wolnej chwili uwzględnie to w pagerze, ale naprawde nie wiem kiedy będzie ta wolna chwila sad.gif
dr_bonzo
A moze dodac dodatkowa klase do generowania linku: podajesz jej numer strony, liczbe stron (+inne) i za jej pomoca generujesz dowonle linki, z mod_rewrite czy bez.
AxZx
dobry pomysl

tylko nie kazdy jest takim geniuszem i nie kazdy wie jaka funkcjonalnosc powinna miec taka klasa.
dr_bonzo
Heh, przeciez opisalem funkcjonalnosc tej klasy.

  1. <?php
  2. function _createLink($title, $page, $text)
  3. {
  4.  
  5. TUTAJ
  6. zamiast tworzyc linka w metodzie, przekazujesz $title, $page, $text obiektowi innej klasy odpowiedzialnego tylko za tworzenie linka. Obiekt ten przekazujesz przy tworzeniu nowego Pager. Zeby zmienic typ linkow wymieniasz tylko obiekt generujacy linki.
  7. PHP5: az sie prosi o interfejs.
  8.  
  9. }
  10. ?>
nospor
Z tą nową klasą to chyba lekka przesada. Aż tyle rzeczy w generowaniu linka nie ma, by tworzyc do tego nową klasę. Wystarczy wzbogacic funkcję _createLink o dodatkową możliwośc i to wszystko. Dojdzie maly bajer i tyle. Nie przesadzajmy.
Funkcję te wzbogace, przy odrobinie czasu jak pisalem.
sf
Pierwsza klasa zwraca obiekt/tablice z danymi, ktore daja podstawe do wyswietlenia tych danych w sposob, ktory nam najbardziej odpowiada. Zamykanie kodu html w klasie, ktora `wylicza` stronicowanie jest malo uniwersalne. Jesli tworzymy juz klase to po to by ja wszedzie wykorzystac.. a nie nagle musimy grzebac w jej srodku bo np. chcemy uzyc obrazkow w szczelkach.
AxZx
czy trwaja prace nad rozbudowa skryptu?smile.gif
nospor
NIestety nie. Powód ciągle ten sam smile.gif

Na przyszłość tego typu pytania prosze kierować na PW (wkoncu taki post nic nie wnosi do tematu. a jakby byla nowa wersj to bym ją umiescil)
basu
Czy wiecie jak zrobić/zodyfikować pagera, aby chodził na PDO?
Probuje cos wykombinować, ale opornie mi to wychodzi.
nospor
pytasz juz o to tutaj: http://forum.php.pl/index.php?showtopic=39...=0&#entry218370
uwazaj, bo to podchodzi pod crossposting

PDO nie uzywalem nigdy. ale jak teraz patrze na jego zestaw funckji to jest tam wykonanie zapytania i pobieranie rekordow. nie wiem wiec w czym problem?zamiast mysql_query wywolyjuesz query PDO
Diablos
A jak zastosowac pagera przy template'ach ? Przykladowo OPT ?
nospor
kurka, jakis dziwny jestem. OPT tez nie uzywalem smile.gif

Ale jak to szablon. W php tworzysz obiekt pagera, generujesz odpowiednie zapytanie tak jak podalem w przykladzie. Do szablonu przekazujesz wynik metody $pager->render(); oraz rzucasz rekordy.

No chyba ze ci ocos innego chodzi
basu
Jednak sobie poradzilem ze stronicowaniem w PDO smile.gif
Problem polegal na tym ,ze $stmt->rowCount() nie dziala poprawnie.
Jesli poprawimy pager na:
  1. <?php
  2. //polaczenie z baza
  3. try 
  4. {
  5.  $db=new PDO('mysql:dbname=table;host=localhost','uzytkownik','haslo');
  6. }
  7. catch (PDOException $e)
  8. {
  9. echo 'Brak dostępu do baz danych: '.$e->getMessage();
  10. }
  11.  
  12. $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  13. ?>
  14.  
  15.  
  16.  
  17.  
  18. <?php
  19.  
  20.  // zapytanie o ilosc rekordów
  21.  $stmt = $db->prepare( "SELECT count(*) FROM table" );
  22.  $stmt->execute();
  23.  while($row=$stmt->fetch()) { $ilosc=$row[0]; }
  24.  $recordsCount = $ilosc;//pobranie liczby rekordów
  25.  $pager = new Pager('idPagera');
  26.  $pager->setRecordsCount($recordsCount);//ustawienie liczby rekordów
  27.  //wygenerowanie pagera i zapamietanie go w zmiennej w celu 
  28.  //pozniejszego wyswietlenia
  29.  $renderPager = $pager->render();
  30.  $start = $pager->getStartRecord();//pobranie indexu rekordu początkowego
  31.  $end = $pager->getEndRecord();//pobranie indexu rekordu koncowego 
  32.  //ustawnienie zmiennej $koniec : LIMIT ($start,->$koniec<-)
  33.  $koniec = $end - $start + 1;
  34. //zapytanie z uwzglenieniem stronicowania
  35. //...pobranie wyników i ich wyswietlenie
  36. $stmt=$db->prepare("SELECT Kolumna FROM table LIMIT $start, $koniec");
  37. $stmt->execute();
  38. $stmt->bindColumn("Kolumna", $kolumna);
  39. while($stmt->fetch(PDO::FETCH_BOUND))
  40. {
  41. echo $kolumna."<br>";
  42. }
  43.  
  44.  
  45.  echo $renderPager; //wyswietlenie pager'a
  46.  
  47. ?>


to chodzi idealnie smile.gif. Polecam ten pager, dobrze sie sprawuje.

Prosze uzywac bbCode - NuLL
nospor
Cytat
Jesli poprawimy pager na:
Ja tylko sprostuje. Tutaj ty nie poprawiles pager'a, tylko kod, który zapodaje dane do pagera i korzysta z jego danych. A dokladniej mowiac dostosowales go do PDO. Kod klasy Pager nie ulegl zadnej zmianie smile.gif
basu
w sumie racja smile.gif
ale najwazniesze ze chodzi.

Za nabijanie postow sa ostrzezenia.... - NuLL
SongoQ
Cytat
Problem polegal na tym ,ze $stmt->rowCount() nie dziala poprawnie.

Jak bys zagladnal do manuala to bys zobaczyl ze dziala poprawnie.

Cytat
PDOStatement::rowCount() returns the number of rows affected by the last DELETE, INSERT, or UPDATE statement executed by the corresponding PDOStatement object.
bigZbig
@nospor -> Z przeczytanych postow dowiedzialem sie ze dokonales pewnych malych poprawek w pierwotnie opublikowanej klasie. Czy klasa zamieszczona w pierwszym poscie jest aktualna wersja Twojej klasy? Jesli mam ja przetestowac to wolalbym to robic na ostatniej wersji aby sie nie zmagac z ewentualnymi, poprawionymi juz bledami.

tak. pierwszy post byl na bieząco aktualizowany (ale prosilem - na PW takie pytania ). tutaj walic uwagi, pytania dotyczace konkretnych rzeczy
---
nospor


Kilka uwag.

Styl kododwania:
Pomieszanie kodu logicznego z warstwa prezentacji np. funkcja render. Ja bym sie starał wszystko doprowadzic do postaci np. tablicy, a nastepnie stworzyl funkcje przetwarzajaca te tablice do postaci html. Uzytkownik mialby do wyboru pobranie gotowego kodu html lub np. poszczegolnych elementow ktore umieszczalby pomiedzy kodem html (np. w postaci tablicy numery stron i gotowe spreparowane urle) Formularz przechowujacy odpowiednie zmienne, niewidoczny dla uzytkownika moglby byc od razu wygenerowany - znaczy sie jego naglowek (no tu widze pewien problem ale to jest jeszcze do przemyslenia) w kazdym razie chodzi o mozliwie najwieksze wydzielenie warstwy prezentacji od warstwy logicznej. Mozna pomyslec o zrobieniu klasy dziedziczacej sluzacej tylko i wylacznie do generowania kodu html. Wtakiej sytuacji moglbys stworzyc kilka wersji klasy potomnej odpowiedzialnej za wyglad pagera. Aha kod domyslny html powinien moim zdaniem oprocz linkow do stron, zawierac tez informacje o ogolnej liczbie rekordow, liczbie rekordow na stronie i ktore to sa bo tak to czesc kodu html dostaje od razu a czesc musze sobie dorobic.

Niejednolite nazewnictwo raz $nazwa_zmiennej a innym razem $nazwaZmiennej i to bez uzasadnienia. Przynajmniej nie dojrzalem szczegolnego powodu.


Usprawnienia:
W Twojej klasie jest jeszcze jeden mankament. Nie ma mozliwosci zmiany tekstow (Strona, Nastapna strona itd.) Powinienes odpowiednie teksty przechowywac osobno np. w zmiennej publicznej - tablicy ($aTexts = array('page' => 'Strona')) - to ulatwi ustawienie wlasnych tekstow. Oczywiscie w kodzie w takim przypadku dajesz np.:
<?php
$ret .= $this->_createLink($aTexts['page'].$i, $i, $i);
?>

Podoba mi sie dolanczanie zmiennej paginatora do danego linku. Jak to juz ktos tutaj wspomnial nie ma mozliwosci tworzenia przyjaznych linkow. Mozna by rzeczywiscie stworzyc osobna klase sluzaca do formatowania urli. Oczywiscie to co masz jest rozwiazaniem domyslnym, ale oprocz tego mozna by dolaczac odpowiednie filtry (pluginy) zmieniajace format linkow.

Co do Twoich uwag ktore funkcje uzywac najpierw, a ktore pozniej. Mozna ustawic zmienna kontrolna $bIsRendered. Nie musze pisac kiedy ustawiasz jej wartosc na true. W kazdym razie jak true to przy probie wywolania fukcji z rodzaju set dajesz komunikat bledu. Analogicznie dla get.

Skoro mamy PHP5 i Ajaxa mozna pomyslec o przyszlosci - wyzwan nie brakuje a taki paginator bylby przydatnym narzedziem.

Tyle na szybcika jak cos jeszcze dostrzege to napisze.
nospor
Cytat
Pomieszanie kodu logicznego z warstwa prezentacji np. funkcja render. Ja bym sie starał wszystko doprowadzic do postaci np. tablicy, a nastepnie stworzyl funkcje przetwarzajaca te tablice do postaci html. Uzytkownik mialby do wyboru pobranie gotowego kodu html lub np. poszczegolnych elementow ktore umieszczalby pomiedzy kodem html (np. w postaci tablicy numery stron i gotowe spreparowane urle) Formularz przechowujacy odpowiednie zmienne, niewidoczny dla uzytkownika moglby byc od razu wygenerowany - znaczy sie jego naglowek (no tu widze pewien problem ale to jest jeszcze do przemyslenia) w kazdym razie chodzi o mozliwie najwieksze wydzielenie warstwy prezentacji od warstwy logicznej. Mozna pomyslec o zrobieniu klasy dziedziczacej sluzacej tylko i wylacznie do generowania kodu html. Wtakiej sytuacji moglbys stworzyc kilka wersji klasy potomnej odpowiedzialnej za wyglad pagera.
Juz podobne głosy padły wcześniej. To jednak faktycznie by się przydało (wczesniej mialem troche inne zdanie na ten temat). Początkowo klasą była robione w javie pod konkretny projekt w jsf, potem potrzebowalem szybko pagera w php i na szybko przerobilem. Zaowocowalo to pewnymi sztywnymi rzeczami jak ten kod html.

Cytat
Aha kod domyslny html powinien moim zdaniem oprocz linkow do stron, zawierac tez informacje o ogolnej liczbie rekordow, liczbie rekordow na stronie i ktore to sa bo tak to czesc kodu html dostaje od razu a czesc musze sobie dorobic.
To juz by zostalo rozwiazane samo, gdyby byla mozliwość wlasnej generacji html (patrz punkt wyzej). Wowczas by se kazdy smazyl jeszcze co by chcial.

Cytat
Niejednolite nazewnictwo raz $nazwa_zmiennej a innym razem $nazwaZmiennej i to bez uzasadnienia. Przynajmniej nie dojrzalem szczegolnego powodu.
Tak, to moje zwykłe niedopatrzenie.

Cytat
W Twojej klasie jest jeszcze jeden mankament. Nie ma mozliwosci zmiany tekstow
To rownież by zostalo rozwiązane przez mozliwość definiowania wlasnego html

Cytat
Co do Twoich uwag ktore funkcje uzywac najpierw, a ktore pozniej. Mozna ustawic zmienna kontrolna $bIsRendered. Nie musze pisac kiedy ustawiasz jej wartosc na true. W kazdym razie jak true to przy probie wywolania fukcji z rodzaju set dajesz komunikat bledu. Analogicznie dla get.
Sluszna uwaga.

Cytat
Skoro mamy PHP5 i Ajaxa mozna pomyslec o przyszlosci
hehe, przeginasz... winksmiley.jpg (żartuję).

Wszystkie uwagi zapisalem se w mej pamięci. jej czyszczenia nie przewiduję w najbliższym czasie winksmiley.jpg. Niestety natłok innych obowiązków i probelmów, odsuwa rozwój tej klasy w przyyyyyszłość... Ale pare osób już jej używa i nie narzeka winksmiley.jpg
Fallout
Witam,

mam problem z tym skryptem, gdyż nie wiem jak wymusić aby startował od danej fotki, bo u mnie to jest tak (co z ponizszego kodu powinno wyniknac) ze
najpierw wyswietla sie menu galerii (ostatni else), gdzie wybiera sie galerie ($gid)
po wybraniu wyswietlaja sie miniaturki i po kliknieciu na dowolna pokazuje sie pager, sek w tym ze nie wyswietla wskaznej fotki ($fid) tylko startuje od pierwszej... btw. $pid = id psa smile.gif

oto kod mojej "galerii":

  1. <?php
  2.  
  3. include 'db_engine.php';
  4.  
  5. $pid = (int)$_GET['p'];
  6.  
  7. $db = new dbengine();
  8. $db->polacz();
  9.  
  10. if(isset($_GET['gid'])and(!isset($_GET['fid'])))
  11. {
  12. $gid = (int)$_GET['gid'];
  13. $db->DoSql("SELECT galeria_katalog FROM galerie WHERE galeria_id = $gid");
  14. $kat = mysql_result($db->wynik,0,0);
  15. $dir = './zdjecia/'.$kat.'/mini/';
  16. $db->DoSql("SELECT * FROM zdjecia WHERE galeria_id = $gid AND pies_id = $pid");
  17. $res = $db->wynik;
  18. while($r=mysql_fetch_array($res))
  19. {
  20. $fname = $r['zdjecie_plik'];
  21. $fid  = $r['zdjecie_id'];
  22. $mini = $dir.$fname;
  23. //echo $fname.'<br>'.$fid.'<br>'.$mini;
  24. // sprawdza czy istnieje wpis w bazie
  25. if($fid<>0)
  26. {
  27. // sprawdza czy miniatrua istnieje
  28. if(file_exists($mini))
  29. {
  30. $link = "<a href=\"?s=galerie&amp;gid=$gid&amp;fid=$fid&amp;p=$pid\">";
  31. echo $link."<img src=\"$mini\" border=\"1\"></a>&nbsp;\n";
  32. }
  33. else // jesli nie, to ją generuje i wyswietla
  34. {
  35. echo "Brak miniatury";
  36. }
  37. }
  38. else echo "Brak wpisu w bazie dla wybranego pliku!<br>\n";
  39. }
  40. }
  41. elseif(isset($_GET['gid'])and(isset($_GET['fid']))) // pokazuje wybrane zdjecie
  42. {
  43. $gid = (int)$_GET['gid'];
  44. $fid = (int)$_GET['fid'];
  45. $db->DoSql("SELECT galeria_katalog FROM galerie WHERE galeria_id = $gid");
  46. $kat = mysql_result($db->wynik,0,0);
  47. $dir = './zdjecia/'.$kat.'/';
  48.  
  49. $db->DoSql("SELECT Count(*) FROM zdjecia WHERE galeria_id = $gid AND pies_id = $pid");
  50. $ile_zdjec = mysql_result($db->wynik,0,0);
  51. if($ile_zdjec==0)
  52. {
  53. echo "Brak zdjęć";
  54. }
  55. else
  56. {
  57. echo '<div align="center"><a href="?s=galerie&amp;gid='.$gid.'&amp;p='.$pid.'">';
  58. echo '<img src="buttony/powrotdogalerii.jpg" border="0"></a></div>';
  59. include 'pager.php';
  60. $pager = new Pager('galeria');
  61. $pager->$_recordsOnPage = 1;
  62. $pager->$_startRecord = $fid;
  63. $pager->setRecordsCount($ile_zdjec);
  64. $renderPager = $pager->render();
  65. $start = $pager->getStartRecord();
  66. $end = $pager->getEndRecord();
  67. $sql = 'SELECT * FROM zdjecia WHERE galeria_id = '.$gid.' AND pies_id = '.$pid.' LIMIT '.$start.','.($end - $start + 1); 
  68. $db->DoSql($sql);
  69. $res=$db->wynik;
  70.  
  71. while($r = mysql_fetch_array($res))
  72. {
  73. $opis = $r['zdjecie_opis'];
  74. $plik = $r['zdjecie_plik'];
  75.  
  76. echo "<br /><img src=\"$dir$plik\" border=\"1\"><br />$opis<br />";
  77. }
  78. echo $renderPager;  
  79. }
  80. }
  81. else 
  82. {
  83. $db->DoSQL("SELECT * FROM galerie WHERE galeria_id <> 4");
  84. $db->NRows;
  85. $w = $db->wynik;
  86. $n = $db->rows;
  87. while ($r=mysql_fetch_array($w))
  88. {
  89. $id  = $r['galeria_id'];;
  90. $pies = $r['pies_id'];
  91. $opis = $r['galeria_nazwa'];
  92. $img = $r['galeria_obrazek'];
  93.  
  94. $scr = "<img src=\"buttony/$img\" border=\"0\" alt=\"$opis\">";
  95. echo "<a href=\"index.php?s=galerie&amp;gid=$id&amp;p=$p\">".$scr."</a><br />";
  96. }
  97.  
  98. $db->rozlacz();
  99.  
  100. }
  101. ?>


zmienna identyfikatora fotki to $fid, moze Wy macie jakis pomysl, bo kazda proba konczy sie tym ze pager nie dziala sad.gif Narazie dziala, ale kilkanie danej miniatury
powoduje ze pager i tak zaczyna od pierwszej fotki..

mam wrazenie, ze to chyba niewykonalne bez zmiany cos w pagrze :/ a zalezy mi na czasie sad.gif no chyba ze cos ja przegapilem :/ mam nadzieje ze cos poradzicie, bo ja sie juz poddalem :]

pozdrawiam
Marcin
nospor
  1. <?php
  2. $pager->$_startRecord = $fid;
  3. ?>
To nie tak dziala smile.gif
ty nie musisz przypisywac od jakiego rekordu ma zaczynac. Wrecz nie mozesz, gdy z zmienna ta jest wyliczana na podstawie aktualnej strony i jest pozniej nadpisywana winksmiley.jpg
pomine juz fakt ze źle dobierasz się do zmiennych klasy. nie:
  1. <?php
  2. $pager->$_recordsOnPage = 1;
  3. $pager->$_startRecord = $fid;
  4. ?>


a:
  1. <?php
  2. $pager->_recordsOnPage = 1;
  3. $pager->_startRecord = $fid;
  4. ?>
Widać rożnicę?Dochodzi do tego jeszcze fakt ze nie mozesz przyspisac startRekord i skraca sie to do:
  1. <?php
  2. $pager->_recordsOnPage = 1;
  3.  
  4. ?>
smile.gif
Teraz dziala?
Fallout
Hehe, wierze na słowo bo nie wiem czemu mimo zeby mnie powiadamilo o odp to nic mi nie przyszlo wiec nie zagladalem smile.gif W miedzy czasie napisalem sobie to wszystko od nowa i nie korzystajac z Twojego pagera smile.gif Choc zostal na ksiazce gosci, gdzie sprawuje sie znakomicie smile.gif

A mój sposób? Oto on:

  1. <?php
  2.  
  3. include 'db_engine.php';
  4.  
  5. $db = new dbengine();
  6. $db->polacz();
  7.  
  8. $pid = (int)$_GET['p']; // id psa
  9. $gid = (int)$_GET['gid']; // id galerii
  10. $eid = (int)$_GET['eid']; // koniec
  11. $cid = (int)$_GET['cid']; // wybrana fotka
  12. // pobranie zdjec
  13. $lsql = 'SELECT * FROM zdjecia WHERE galeria_id = '.$gid.' AND pies_id = '.$pid;
  14. $db->DoSql($lsql);
  15. $lres=$db->wynik;
  16. // pobranie katalogu
  17. $db->DoSql("SELECT galeria_katalog FROM galerie WHERE galeria_id = $gid");
  18. $kat = mysql_result($db->wynik,0,0);
  19. $dir = './zdjecia/'.$kat.'/';
  20. $dir_mini = './zdjecia/'.$kat.'/mini/';
  21. // wypelnienie tablicy danymi
  22. $temp = array();
  23. $count = 0;
  24. while($r = mysql_fetch_array($lres))
  25. {
  26. $opis = $r['zdjecie_opis'];
  27. $plik = $r['zdjecie_plik'];
  28. $dane = array($count,$dir.$plik,$opis,$dir_mini.$plik);
  29. $temp[$count] = implode(',',$dane); 
  30. $count++;
  31. }
  32. $lista = $temp;
  33.  
  34. if(isset($_GET['gid'])and(!isset($_GET['cid']))) // wyswwietla miniatury
  35. {
  36. if($count<>0)
  37. {
  38. foreach($lista as $id)
  39. {
  40. $data = explode(',',$id);
  41. $cid = $data[0]; // id
  42. $plk = $data[1]; // plik
  43. $ops = $data[2]; // opis
  44. $min = $data[3]; // mini
  45.  
  46. if(file_exists($min))
  47. {
  48. $link = "<a href=\"?s=galerie&amp;gid=$gid&amp;eid=$count&amp;cid=$cid&amp;p=$pid\">";
  49. echo $link."<img src=\"$min\" border=\"1\"></a>&nbsp;\n";
  50. }
  51. }
  52. }
  53. else echo '<br /><img src="buttony/brakzdjec.jpg"><br /><br />';
  54. }
  55. elseif(isset($_GET['gid'])and(isset($_GET['cid']))) // pokazuje wybrane zdjecie
  56. {
  57. $dane = $lista[$cid];
  58. $data = explode(',',$dane);
  59. $cid = $data[0]; // id
  60. $plk = $data[1]; // plik 
  61. $ops = $data[2]; // opis
  62. $min = $data[3]; // mini
  63.  
  64. if(file_exists($min))
  65. {
  66. $next='';
  67.  
  68. if($cid+1<$eid)
  69. {
  70. $ncid = $cid+1;
  71. $next ='<a href="?s=galerie&amp;gid='.$gid.'&amp;p='.$pid.'&amp;cid='.$ncid.'&amp;eid='.$count.'">';
  72. $next.='<img src="buttony/nav_1a.jpg" border="0"></a>';
  73. }
  74.  
  75. $prev='';
  76.  
  77. if($cid-1>0)
  78. {
  79. $pcid=$cid-1;
  80. $prev='<a href="?s=galerie&amp;gid='.$gid.'&amp;p='.$pid.'&amp;cid='.$pcid.'&amp;eid='.$count.'">';
  81. $prev.='<img src="buttony/nav_1b.jpg" border="0"></a>';
  82. }
  83.  
  84. echo '<div align="center">'.$prev;
  85. echo '<a href="?s=galerie&amp;gid='.$gid.'&amp;p='.$pid.'">';
  86. echo '<img src="buttony/powrotdogalerii.jpg" border="0"></a>';
  87. echo $next.'</div>';
  88.  
  89. echo '<img src='.$plk.' border="1"><br /><b>'.$ops.'</b>';
  90. }
  91. }
  92. else // wyswietlenie listy galerii
  93. {
  94. $db->DoSQL("SELECT * FROM galerie WHERE galeria_id <> 4");
  95. $db->NRows;
  96. $w = $db->wynik;
  97. $n = $db->rows;
  98. while ($r=mysql_fetch_array($w))
  99. {
  100. $id  = $r['galeria_id'];;
  101. $pies = $r['pies_id'];
  102. $opis = $r['galeria_nazwa'];
  103. $img = $r['galeria_obrazek'];
  104.  
  105. $scr = "<img src=\"buttony/$img\" border=\"0\" alt=\"$opis\">";
  106. echo "<a href=\"index.php?s=galerie&amp;gid=$id&amp;p=$p\">".$scr."</a><br />";
  107. }
  108. }
  109.  
  110. ?>


I mam pytanie, czy to nie jest efektywniejsze?
Jedyna wada, ze nie ma menu 1..n, ale nastepny/poprzedni co 10 itp. latwo zrobic..
jesli oftop to usune smile.gif
nospor
Cytat
I mam pytanie, czy to nie jest efektywniejsze?
Zazwyczaj zamienienie klasy na bezposredni kod jest efektywniejsze (o ile sie nic nie zepsuje po drodze winksmiley.jpg ). Klasa ma za zadanie ulatwic i przysieszyc pisanie aplikacji, a nie odkrywać ciągle wszystko na nowo. Często klasy uogolniają wiele sytuacji, przez co mozna je stosowac w szerszym zakresie, ale to powoduje zmniejszenie wydajności (w mniej lub większy sposó winksmiley.jpg )

Co do Twojego skryptu, to nie mam sily/czasu go analizowac. Ale jesli ci dziala i ci wystarcza, to uzywaj do woli winksmiley.jpg No i napewno ma zdecydowanie mniej kodu niz moja klasa smile.gif
Legro
witam, nie moge sobie z tym poradzic, probowalem juz z 10 kodow na stronicowanie i nic :/ z tego forum z compzone.org z forum.webhelp.pl i nie umie zadnego przystosowac.. widze ze Twoja klasa cieszy sie popularnoscia, ze tak powiem ale tez nie moge jej przystosowac.. wiec mam prosbe.. czy jestes w stanie przystosowac, nospor? ew. jak ktos inny potrafi to bardzo prosze winksmiley.jpg



moj kod jest taki:

  1. <?php
  2.  
  3. $dowcipy = mysql_query (" Select * From `dowcipy` Where `akt_d` = '1' and `kat_d` = '{$_GET['id_kat']}' ");
  4. $num_row = mysql_num_rows ( $dowcipy );
  5.  
  6. if ( $num_row != 0 ) {
  7.  
  8. while ( $r_dowcipy = mysql_fetch_array ( $dowcipy, MYSQL_ASSOC )) {
  9.  
  10. $list_dowcipy .= ( nl2br ( $r_dowcipy['tresc_d'] ) . '<br /><br />' ); 
  11.  
  12. }
  13.  
  14. $template -> setValue ('lista_dowcipow', $list_dowcipy);
  15.  
  16. } else {
  17.  
  18. $template -> setValue ('lista_dowcipow', 'Brak dowcipów w kategorii.');
  19.  
  20. }
  21.  
  22. ?>



To jest kod do wyswietlana... i chcialbym aby na stronie bylo po 10 wpisow.
Levabul
NIe wiem czy ktoś zauważył ale w 128 lini jest literówka (brak znaku dolara "$" przed zmienną pon) przez którą cała klasa się sypie bo wyświetlany jest błąd
Kod
Error: Division by zero
czy jakoś tak tongue.gif. Poprawna linia 128:
  1. <?php
  2. $this->_pagesOnNav = $pon;
  3. ?>
nospor
@legro w pierwszym poscie masz co i jak...
  1. <?php
  2.  
  3. $sql = "select count(*) from dowcipy Where `akt_d` = '1' and `kat_d` = '{$_GET['id_kat']}'  " ;
  4.    $result = mysql_query($sql);
  5.    $row = mysql_fetch_array($result);
  6.    $num_row = $row[0];//pobranie liczby rekordów
  7.    $pager = new Pager('idPagera');
  8.    $pager->setRecordsCount($num_row);//ustawienie liczby rekordów
  9.    //wygenerowanie pagera i zapamietanie go w zmiennej w celu 
  10.    //pozniejszego wyswietlenia
  11.    $renderPager = $pager->render();
  12.    $start = $pager->getStartRecord();//pobranie indexu rekordu początkowego
  13.    $end = $pager->getEndRecord();//pobranie indexu rekordu koncowego
  14.    //zapytanie z uwzglenieniem stronicowania
  15.    $sql = "select * from dowcipy Where `akt_d` = '1' and `kat_d` = ".$_GET['id_kat']."   limit ".$start.','.($end - $start + 1); 
  16.    //...pobranie wyników i ich wyswietlenie, czyli twoj kod:
  17. $dowcipy = mysql_query($sql);
  18. if ( $num_row != 0 ) {
  19.  
  20. while ( $r_dowcipy = mysql_fetch_array ($dowcipy , MYSQL_ASSOC )) {
  21.  
  22. $list_dowcipy .= ( nl2br ( $r_dowcipy['tresc_d'] ) . '<br /><br />' ); 
  23.  
  24. }
  25.  
  26. $template -> setValue ('lista_dowcipow', $list_dowcipy);
  27.  
  28. } else {
  29.  
  30. $template -> setValue ('lista_dowcipow', 'Brak dowcipów w kategorii.');
  31.  
  32. }
  33. //////
  34.  
  35.    echo $renderPager; //wyswietlenie pager'a
  36.  
  37.  
  38. ?>


@Levabul wielkie dzięki smile.gif nie wiem skąd ta literowka sie tam wytrzasnęła
Legro
@nospor - wielkie dzięki.. Działa wszystko ok, wyświetla się lista:

1 2 3 >

Ale jak chce kliknac na 2 to nic sie nie robi... Na pasku statusu pisze tylko jak najade na cyferke 2: java script:sub_function_1(2);

I nie da sie przejsc na druga strone wynikow :/


------------ EDIT

Już wiem dlaczego tak sie dzieje..

Robie tak:

  1. <?php
  2.  
  3. $template -> setValue ('pages', $renderPager);
  4.  
  5. ?>


Zamiast tak
  1. <?php
  2. echo $renderPager;
  3. ?>


Da sie to jakos zastapic? Aby mi dzialalo to co najpierw podalem? Chce to wrzucic do szablonu w inne miejsce :/

Pozdrawiam.
bohusz
Witam
Jak połaczyć pager z tym kodem wyszukiwarki?
W kodzie jest stronicowanie, ale ono niestety nie działa.
Z góry dziękuję za pomoc, nie znam się na php a bardzo mi zależy na poprawnym stronicowani.

  1. <?
  2. $ile = mysql_num_rows(mysql_query("SELECT * FROM $ogloszenia_table $where"));
  3. $result = mysql_query("SELECT * FROM $ogloszenia_table $where LIMIT $limit,$og_limit");
  4.  
  5. while($r = mysql_fetch_array($result)){
  6. $id = $r['id'];
  7. $cat = $r['cat'];
  8. $title = $r['title'];
  9. $img1 = $r['img1'];
  10. $date = $tbl['date'];
  11. if($img1 == '1'){ $photo = '<a href="lista.php?id='.$id.'"><img id=intro src="img/'.$id.'_1.gif" border="0" width="50px"></a>'; } else{ $photo = ''; }
  12. echo'<fieldset>'.$photo.'Fotoanons: <br /><a href="lista.php?id='.$id.'">'.$title.'</a></fieldset><br />';
  13. }
  14. if($ile == '0'){ echo'brak wyniku'; }
  15.  
  16.  
  17. ?>


Jeszcze raz z góry dziękuję
nospor
  1. <?php
  2.  
  3. $sql = "SELECT count(*) FROM $ogloszenia_table $where";
  4.    $result = mysql_query($sql);
  5.    $row = mysql_fetch_array($result);
  6.    $recordsCount = $row[0];//pobranie liczby rekordów
  7.    
  8.  $pager = new Pager('idPagera');
  9.    $pager->setRecordsOnPage($og_limit);
  10.    $pager->setRecordsCount($recordsCount);//ustawienie liczby rekordów
  11.    //wygenerowanie pagera i zapamietanie go w zmiennej w celu 
  12.    //pozniejszego wyswietlenia
  13.    $renderPager = $pager->render();
  14.    $start = $pager->getStartRecord();//pobranie indexu rekordu początkowego
  15.    $end = $pager->getEndRecord();//pobranie indexu rekordu koncowego
  16.    //zapytanie z uwzglenieniem stronicowania
  17.    $sql = "SELECT * FROM $ogloszenia_table $where limit ".$start.','.($end - $start + 1);
  18.    $result = mysql_query($sql); 
  19.    while($r = mysql_fetch_array($result)){
  20. $id = $r['id'];
  21. $cat = $r['cat'];
  22. $title = $r['title'];
  23. $img1 = $r['img1'];
  24. $date = $tbl['date'];
  25. if($img1 == '1'){ $photo = '<a href="lista.php?id='.$id.'"><img id=intro src="img/'.$id.'_1.gif" border="0" width="50px"></a>'; } else{ $photo = ''; }
  26. echo'<fieldset>'.$photo.'Fotoanons: <br /><a href="lista.php?id='.$id.'">'.$title.'</a></fieldset><br />';
  27. }
  28.    echo $renderPager; //wyswietlenie pager'a
  29. if($recordsCount == ){ echo'brak wyniku'; }
  30.  
  31. ?>
widze ze dales duzo rekordow na stronie: 150. wow winksmiley.jpg

ps: zaraz usune wiekszą czesc Twego kodu, gdyz generowanie formularza nam do szczescia nie jest potrzebne smile.gif
ps2: i uzywaj na przyszlosc wlasciwego bbcode
acztery
świetna sprawa . ale brakuje mi tu tego co już ktoś wcześniej napisał ze jak jeste na 10 stronie powinno automatycznie przskoczyc na nastepnych 10 a nie ze trzeba kliknac na " >> " dziala szybko na 600 tys rekorach. z tym ze liczenie rekordów robie tak:

  1. <?php
  2.  
  3.  $sql="SELECT COUNT(patch) as ile FROM prg  WHERE patch LIKE '%$CAT%'";
  4.  $result = mysql_query($sql);
  5.  $recordsCount = mysql_result($result,0,"ile"); 
  6.  
  7. ?>
nospor
Widzę, ze nie dacie mi spokoju z tymi pare przed i pare po od danej strony. Wprowadzilem więc poprawki w pierwszym poście na tę okoliczność smile.gif
Sposób uzywania klasy nie uległ zmianie (jest kompatybilna wstecz smile.gif ). Chcąc użyc nowej metody generowania linków, wystarczy wywołać metodę render() z parametrem true:
  1. <?php
  2. echo $pager->Render(true);
  3. ?>

Mam nadzieję, że w ten sposób usatysfakcjonowałem parę osób winksmiley.jpg

edit: jesli ktos nie wie o jakich zmianach mowie, to zacytuje jednego z uzytkowników:
Cytat
czy nie lepiej by bylo gdyby np przy 10 podstronie widoczne byly linki do stron nastepnych i poprzednich?
np 5 poprzednich i 5 nastepnych, bo teraz jest tak ze jest 10 stron i koniec, tylko strzalki w prawo sa.
a co do linkow to chodzi mi o cyfry

teraz jest
CODE

|< << < 1 2 3 4 5 6 7 8 9 |10| > >> >|


gdzie |10| to aktualna strona

a ja zapytalem czy nie moze to sie przesuwac
np.
CODE

|< << < 5 6 7 8 9 |10| 11 12 13 14 15 > >> >|



moze takie cos juz jest ?
No i teraz juz tak jest
acztery
jeszcze zapamietywanie podstron w sesjach i bedzie perfekto

EDIT

aha mam male pytanie przy 500 tys rekordów pierwsze uruchomienie skryptu trwa długo u Was też?
nospor
Cytat
jeszcze zapamietywanie podstron w sesjach i bedzie perfekto
No przecież to jest smile.gif proponuję przeczytac opis klasy na początku kody, oraz posty w topicu. Zapamietywanie w sesji bylo przez caly czas. Co poniektórzy chcieli by mozna bylo to wyłączyc, więc dorobilem i tę mozliwość. ale domyslnie jest wlączone zapamietywanie w sesji. Moze ty nie startujesz sesji i dlatego ci nie dziala winksmiley.jpg
acztery
tak masz racje nie mam session_start()


a co z tym 1 wolnym uruchomieniem
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-2024 Invision Power Services, Inc.