Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> [inny]Route w Laravel
damian1
post
Post #1





Grupa: Zarejestrowani
Postów: 9
Pomógł: 0
Dołączył: 23.04.2014

Ostrzeżenie: (0%)
-----


Witam
Chciałbym uzyskać taki efekt możliwie najprostszym sposobem:
../category/subcategory/id ze wszystkimi możliwymi kombinacjami np: .../id, ../subcategory, ../subcategory/id

Otóż w zasadzie napisałem kod, który działa. Trzy niewiadome były jeszcze znośne, ale potrzebuje jeszcze utworzyć podobny na ok. 5 niewiadomych (już sama myśl mnie przeraża), dlatego chciałem się spytać czy nie ma czasem jakiegoś prostszego sposobu? Mam przeczucie, że jednak nie do końca wykorzystuje możliwości frameworka (mój pierwszy projekt).

A jeśli chodzi o wady poniższego kodu to:
-każdorazowo muszę sprawdzać 'category_name', czyli po prostu warianty kategorii. Jest ich ok.7, więc jest jeszcze ok.
-sam kod to potworek (wkleiłem tylko pierwszy szkielet). W rzeczywistości w każdym if-ie rozważanych jest jeszcze kilka możliwości z każdorazowym połączeniem z bazą danych.

routes.php
  1. Route::get('home/{category?}/{subcategory?}/{id?}', array('as' => 'home/{category?}/{subcategory?}/{id?}', 'uses' => 'HomeController@test'))->where(array('id' => '[0-9]+'));



HomeController
  1. public function test($category= null, $subcategory = null, $id = null ) {
  2.  
  3. if ($category && $subcategory && $id) {
  4. return 'Kategoria: '.$category.'</br>'.'Subcategory: '.$subcategory.'</br>'.'Id: '.$id.'</br>';
  5. } elseif ($category && $subcategory) {
  6. if( $subcategory > 0 ) {$id = $subcategory; $subcategory= null;}
  7. if( $category != 'category_name') {$subcategory = $category; $category= null;}
  8. if( $category != 'category_name' && $id == null) {return Redirect::to('home');}
  9. return '2 opcja:<br>Kategoria: '.$category.'</br>'.'Subcategory: '.$subcategory.'</br>'.'Id: '.$id.'</br>';
  10. } elseif ($category) {
  11. if( $category > 0) {$id = $category; $category= null;}
  12. elseif( $category != 'category_name') {$subcategory = $category; $category= null;}
  13. return '3 opcja:<br>Kategoria: '.$category.'</br>'.'Subcategory: '.$subcategory.'</br>'.'Id: '.$id.'</br>';
  14. }
  15. else {
  16. return "4 opcja";
  17. }
  18. }



Do tego wszystkiego dochodzi parę drobnych filtracji przesyłanych za pomocą sesji, w zależności od tego co wybierze użytkownik w checkbox-ie.

Ten post edytował damian1 8.09.2014, 17:50:53
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
damian1
post
Post #2





Grupa: Zarejestrowani
Postów: 9
Pomógł: 0
Dołączył: 23.04.2014

Ostrzeżenie: (0%)
-----


Dziękuję za podpowiedzi, z pewnością niektóre wykorzystam, aczkolwiek nie rozwiązują do końca moich problemow.
A w zasadzie 1 problemu: jak szybko rozpoznać, że {category}, nie jest {subcategory} i podam przykład:
www.adres-strony.pl/krajobraz/góry/skały/
I jeśli użyłbym $request = Request::segment(2) pobrałoby góry, a jeśli adres wyglądałby inaczej:
www.adres-strony.pl/krajobraz/skały/
pobrałoby skały i powstałby mały konflikt w bazie danych:
1)$photos = Photo::where('kryterium_ksztalt_terenu', '=', $request)->get();
2)$photos = Photo::where('kryterium_przedmiot', '=', $request)->get();
a nie mógłbym na stałe użyć pierwszego adresu, bo skały są nie tylko w górach, ale też na nizinach, nad morzem...
Poprzez sesje filtruje dodatkowo (w razie potrzeby) kolor, rozmiar, kształt...

W moim pierwszym kodzie miałem 3 "niewiadme".
Wersja z 2 możliwościami (Request::segment(1), Request::segment(2)) // www.adres-strony.pl/kategoria/7
Id potraktowana jako liczba
  1. elseif ($category && $subcategory) {
  2. if( $subcategory > 0 ) {$id = $subcategory; $subcategory= null;}

Na wyjściu otrzymuje $category=kategoria, $galeria=null, $id=7 i teraz mogę wygodnie przeszukiwać bazę danych.
Problem polega na tym, że muszę jeszcze rozważyć kategoria/galeria ; galeria/5, czyli rozróżnić kategorie i galerię.
W związku z tym przeszukuje z góry ustalone możliwości kategorii i jeśli ich nie znajduję ustawiam $kategoria=null,
$galeria= to co wpisane;


I teraz podobny problem muszę rozważyć na pięciu niewiadomych. Myślałem, że jest jakiś prostszy sposób, ale bez własnej funkcji chyba się jednak nie obejdzie. I teraz pytanie jak zrobić to najbardziej optymalnie? Na razie najlepszy pomysł jaki mi przychodzi do głowy to przedrostki:
kat-kategoria,sub-subcategoria... tylko nie w Route, bo by nie działało, tylko po prostu jako nazwy i odpowiednio je później wykryć. Nie mniej tego wolałbym uniknąć.


Dziękuje za dotychczasowa pomoc.


<!-- EDIT -->
Ok, albo w sumie zrobię jak mówicie, a skałę potraktuje jako wyjątek i będzie ewentualnie dosyłana w sesji.
Mam jeszcze tylko kilka pytań optymalizacyjnych (w sumie może głupie, ale tylko domyślam się niektórych odpowiedzi). Ktoś ma doświadczenie co może być szybsze?
1) Zapisanie kategorii, subkategorii w bazie danych jako 1,2,3..... i filtrowanie w PHP if($category == 'gory'){$category =1;} i wyszukanie: ...where('category', '=', $category)..., czy od razu zapisanie w bazie danych "stringów"?
2)Powinienem stworzyć relacyjną bazę danych np: category, subcategory, subcategory2 - 1 tabelka, tile, lokazlizacja, opis, widoczność - 2 tabelka? Czy nie będzie przeszkadzało jak bede miał wszystko w 1 tabelce z indeksowaniem, niektórych kolumn?

albo jakaś dobra strona, gdzie mógłbym o tym doczytać...

Ten post edytował damian1 9.09.2014, 10:54:23
Go to the top of the page
+Quote Post

Posty w temacie


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 - 21:27