eGospodarka.pl
eGospodarka.pl poleca

eGospodarka.plGrupypl.comp.wwwCSS - problem z selektorem
Ilość wypowiedzi w tym wątku: 35

  • 21. Data: 2012-02-27 13:32:21
    Temat: [OT] Re: CSS - problem z selektorem
    Od: Paweł Piskorz <n...@p...nie?>

    W dniu 2012-02-27 14:08, M.G. pisze:
    > Jestem ciekaw co to za CMS, bo pluginy powinny mieć dostęp do info na temat
    > otoczenia.

    MZ jeżeli moduł ma kilka różnych wariantów, to powinna istnieć możliwość
    wyboru danego wariantu. Jeżeli by robił warunki w szablonie modułu w
    zależności od tego kogo ma za sąsiada to już za rok będzie miał masę
    ifów, każdy do innego serwisu.
    Tylko czy szerokość modułu jest tutaj takim wariantem? To by było ciut
    bez sensu, bo np. ten sam moduł tekstowy może być użyty w artykule, w
    prawej kolumnie a także na stronie 404.

    > Zresztą musi istnieć jakaś możliwość generowania własnych
    > zmiennych w szablonach, więc przekazanie flagi nie powinno być problemem.

    Przekazanie flagi pewnie nie jest problemem, zaś jej ustawienie to dla
    niego sporo zmian. Przypuszczam że ma tak, iż klient sobie po prostu
    włącza/wyłącza dany moduł (w przeciwieństwie do np. wybierania przy
    tworzeniu podstrony czy to będzie artykuł z galerią czy bez), więc
    dodawanie ręczne odpada, bo klient najzwyczajniej zapomni :)


    --
    message[autor="PablO"]::after {
    content:"Pozdrawiam";
    }


  • 22. Data: 2012-02-27 15:10:16
    Temat: Re: [OT] Re: CSS - problem z selektorem
    Od: "M.G." <k...@t...zna>

    On Mon, 27 Feb 2012 14:32:21 +0100, Paweł Piskorz wrote:

    > W dniu 2012-02-27 14:08, M.G. pisze:
    >> Jestem ciekaw co to za CMS, bo pluginy powinny mieć dostęp do info na temat
    >> otoczenia.
    >
    > MZ jeżeli moduł ma kilka różnych wariantów, to powinna istnieć możliwość
    > wyboru danego wariantu. Jeżeli by robił warunki w szablonie modułu w
    > zależności od tego kogo ma za sąsiada to już za rok będzie miał masę
    > ifów, każdy do innego serwisu.

    No ale na tym poziomie właśnie serwisy się różnią. Może ja nie rozumiem
    tutaj słowa "moduł" ale dla mnie to jest jednostka funkcjonalna, co w żaden
    sposób nie determinuje generowanego przez nią kodu. Ja bym się wręcz
    spodziewał pełnej kontroli nad kodem wypluwanym przez CMSa, generując
    widoki w zależności od sytuacji i pobierając z niego info o stanie
    środowiska dla zadanego requestu. To byłoby dla mnie budowanie "szablonów"
    dla danego serwisu. Coś, co jest customowe tak czy siak. Totalnie odrzuca
    mnie sytuacja, w której o HTMLu wynikającym z działania jakiegoś modułu
    definiuje tylko i wyłącznie moduł.


    > Tylko czy szerokość modułu jest tutaj takim wariantem? To by było ciut
    > bez sensu, bo np. ten sam moduł tekstowy może być użyty w artykule, w
    > prawej kolumnie a także na stronie 404.

    Chyba naprawdę inaczej rozumiemy "moduł" :-).


    >> Zresztą musi istnieć jakaś możliwość generowania własnych
    >> zmiennych w szablonach, więc przekazanie flagi nie powinno być problemem.
    >
    > Przekazanie flagi pewnie nie jest problemem, zaś jej ustawienie to dla
    > niego sporo zmian.

    Hm, ale jakich? Tzn. nie wyobrażam sobie, że nie mogę się dowiedzieć czy
    dany request wypluwa przykładowo jakieś newsy czy nie.


    > Przypuszczam że ma tak, iż klient sobie po prostu
    > włącza/wyłącza dany moduł (w przeciwieństwie do np. wybierania przy
    > tworzeniu podstrony czy to będzie artykuł z galerią czy bez), więc
    > dodawanie ręczne odpada, bo klient najzwyczajniej zapomni :)

    OK, chyba jestem skażony Wordpressem.


    --
    M.G.


  • 23. Data: 2012-02-27 16:11:23
    Temat: Re: CSS - problem z selektorem
    Od: Borys Pogoreło <b...@p...edu.leszno>

    Dnia Sun, 26 Feb 2012 11:46:56 +0100, Marek napisał(a):

    > Sekcja <aside> może nie pojawiać się w kodzie HTML lecz nie musi (CMS ją
    > moze wygenerować lub nie). Chciałbym aby w przypadku gdy nie ma <aside>
    > ustawić szerokość <section> na np. 800px. Czy da się to jakoś zadeklarować
    > w CSS?

    aside { width : 200px; }
    section { width : 900px; }
    section + aside { width : 700px; }

    Też kiedyś to niepotrzebnie komplikowałem ;)

    --
    Borys Pogoreło
    borys(#)leszno,edu,pl


  • 24. Data: 2012-02-27 16:16:17
    Temat: Re: CSS - problem z selektorem
    Od: "M.G." <k...@t...zna>

    On Mon, 27 Feb 2012 17:11:23 +0100, Borys Pogoreło wrote:

    > Dnia Sun, 26 Feb 2012 11:46:56 +0100, Marek napisał(a):
    >
    >> Sekcja <aside> może nie pojawiać się w kodzie HTML lecz nie musi (CMS ją
    >> moze wygenerować lub nie). Chciałbym aby w przypadku gdy nie ma <aside>
    >> ustawić szerokość <section> na np. 800px. Czy da się to jakoś zadeklarować
    >> w CSS?
    >
    > aside { width : 200px; }
    > section { width : 900px; }
    > section + aside { width : 700px; }
    >
    > Też kiedyś to niepotrzebnie komplikowałem ;)

    A nie psuje się w IE8?


    --
    M.G.


  • 25. Data: 2012-02-27 16:59:22
    Temat: Re: CSS - problem z selektorem
    Od: Borys Pogoreło <b...@p...edu.leszno>

    Dnia Mon, 27 Feb 2012 17:16:17 +0100, M.G. napisał(a):

    >> aside { width : 200px; }
    >> section { width : 900px; }
    >> section + aside { width : 700px; }
    >>
    >> Też kiedyś to niepotrzebnie komplikowałem ;)
    >
    > A nie psuje się w IE8?

    Selektor + obsługuje nawet IE7.

    --
    Borys Pogoreło
    borys(#)leszno,edu,pl


  • 26. Data: 2012-02-27 21:20:34
    Temat: Re: CSS - problem z selektorem
    Od: Marek <p...@s...com>

    Dnia Mon, 27 Feb 2012 11:06:12 +0100, M.G. napisał(a):

    >> Nie, zupełnie inaczej to realizuję - o tym dalej.
    >
    > Realizujesz to jak inni, serio.

    Ok :-)

    >
    >> - formatki zawierają markery bloków, które CMS ma powielać (np. sekcja
    >> newsów to wielokrotnie powielony taki blok HTML)
    >
    > Czyli CMS generuje HTMLa.

    Poniekąd oczywiście, że tak. Starałem się jednak sprecyzować co znaczy dla
    mnie "generowanie". Może inaczej to wyjaśnię. W/g mojej definicji
    "generowanie" zachodzi wtedy gdy w kodzie np. PHP znajdziemy coś w stylu:

    print("<div>");

    Czyli generowanie (w mojej definicji) to jest tworzenie kodu jakiego
    fragmentów nie było w formatce.

    > Powielenie sekcji to jest generowanie HTMLa.
    > Wszystko co robi CMS jako wynik swojej pracy, to generowanie HTMLa
    > (ewentualnie JSONa, RSSa, czegokolwiek co potrzebne), jedyna różnica może
    > tkwić w tym czy masz kontrolę nad kodem, który generuje (dobry CMS) czy nie
    > masz (kod "zaszyty" na sztywno, zły CMS, ewentualnie zły moduł).

    To kwestie leksykalne. Powyżej zdefiniowałem to co miałem na myśli.

    >
    > Czyli CMS generuje HTMLa, w dodatku podmieniając atrybuty elemenentów. Nie
    > przeszkadza Ci, że zmienia "id" ale przeszkadza, że zmieni "class"?

    Dokładnie trafiłeś w sedno. Nie przeszkadza mi kostrukcja w kodzie HTML:

    <a href="dokument_TU_WSTAW_ID.html">link do mojego dokumentu</a>

    a bardzo mi przeszkadza:

    <p class="TU_WSTAW_KLASĘ">bla bla</p>

    Gdy w przeglądarce czy edytorze WYSIWYG popatrzysz na kod drugi, to
    niepoprawnie go wyświetli gdyż nie ma klasy w CSS o nazwie
    "TU_WSTAW_KLASĘ". Znacznik umieszczony w linku nie przeszkadza.

    >> Nie są w żadnym przypadku podmieniane nazwy klas CSS bo skąd CMS miałby
    >> wiedzieć na jakie?
    >
    > Bo go o tym poinformujesz? Skoro informujesz go o HTMLu, który ma
    > generować, to możesz go poinformować o atrybutach, które ma generować.

    Osobiście stronię od takich rozwiązań. Bardzo trudno poruszać się po kodzie
    obfitującym w "widoczne inaczej" sekcje. To tak jak programowanie w kodzie
    maszynowym zamiast w językach wyższego rzędu.

    >
    > CMS jest zawsze aplikacją dedykowaną konkretnemu serwisowi.

    U mnie nigdy tak nie jest. Praktycznie wszędzie CMS jest identyczny.
    Zmieniają się tylko zainstalowane lub włączone moduły. O funkcjonalności
    decyduje formatka HTML. Ona poza szatą graficzną zawera specjalne markery
    (nie zaburzające validacji ani wyglądu) sterujące CMSem.

    > To nie musi
    > oznaczać modyfikacji samego CMSa ale jeśli CMS nie dostarcza narzędzi,
    > które pozwalają na zareagowanie inaczej w dwóch różnych sytuacjach... to
    > jest jakaś stara Joomla?

    Nie w tym rzecz. CMS jest autorski. Mie ma potrzeby aby moduł np.
    generujący menu wiedział o tym, że ma reagować inaczej gdy dokument
    wyświetlany na tej samej stronie ma obrazki lub nie ma - czyli pojawi się
    lub nie kolumna <aside> w naszym przypadku. Takie sprawy rozwiązuje się za
    pomocą CSS. Jordan zaproponował zgrabne rozwiązanie - zerknij tam. Jestem
    zwolennikiem przejrzystości kodowania tak aby rozwiązania zastosowane przez
    ich autora były samokomentujące się. Dlatego wstawianie znaczników w
    miejsce klas psuje taką koncepcję.

    > Generowanie różnych klas dla różnych widoków jest podstawową praktyką przy
    > korzystaniu z CMSa, na tym polega "separacja". To dlatego np. Worpdress ma
    > funkcje generujące klasy dla BODY, które pozwalają ostylować inaczej każdy
    > widok (stronę, kategorię, taksonomię, post, archiwum, cokolwiek), czy
    > dodaje klasy typu "current_page_item" jeśli z URLa wynika, że aktualnie
    > jesteś na danej podstronie.

    A nie lepiej podmienić plik CSS gdy potrzebujemy coś inaczej mieć
    ostylowane lub zarządzać mediami na poziomie CSS? Chyba tylko wtedy
    istnieje potrzeba zmiany stylu (dla drukarki inaczej dla ekranu inaczej).
    Kwestię ostylowania podstron też prosto można rozwiązać bez używania
    "wstrzykiwanych" klas. Wystarczy dla podstron zbudować inną formatkę z
    innymi klasami. Wtedy ktoś kto grzebie w naszym kodzie zobaczy jak wyglądać
    będzie taka podstrona bez uruchamiania CMS i łatwo będzie mógł ja
    zmodyfikować. Gdy natomiast CMS będzie podrzucał w locie jakąś klasę to
    marnie widzę szansę na zlokalizowanie kodu bez konsultacji z jego autorem.

    >> Owszem, wtedy jest czasem
    >> trudniej coś ostylować gdy raz jakiś blok pojawia się a innym razem nie.
    >
    > Gdy raz jakiś blok się pojawia, a raz nie, to masz do czynienia z dwoma
    > różnymi widokami.

    Może nie do końca rozumiem tą koncepcję. Co znaczy "widok" w tym przypadku?
    Skąd jest on brany i jakie są kryteria wyłonienia właściwego? Jeśli to
    jakiś moduł programowy go określa - wydaje mi się niepotrzebnym tworzenie
    takiego modułu jeśli CSS to załatwia. Wydaje mi się to szalenie złożoną
    ideą do prostych zadań. Załóżmy, że mamy dokument z 3 kolumnami, z których
    każda z nich może pojawić się lub nie. Czy to oznacza, że musimy
    wygenerować 6 widoków spełniających wszelkie kombinacje? Czyli liczba
    widoków może dążyć do nieskończoności gdy kolumn jest więcej.


  • 27. Data: 2012-02-27 21:32:03
    Temat: Re: CSS - problem z selektorem
    Od: Marek <p...@s...com>

    Dnia Mon, 27 Feb 2012 17:11:23 +0100, Borys Pogoreło napisał(a):

    >> Sekcja <aside> może nie pojawiać się w kodzie HTML lecz nie musi (CMS ją
    >> moze wygenerować lub nie). Chciałbym aby w przypadku gdy nie ma <aside>
    >> ustawić szerokość <section> na np. 800px. Czy da się to jakoś zadeklarować
    >> w CSS?
    >
    > aside { width : 200px; }
    > section { width : 900px; }
    > section + aside { width : 700px; }
    >
    > Też kiedyś to niepotrzebnie komplikowałem ;)

    Pisząc tu liczyłem na to, że ktoś przetarł szlaki :-)
    Jednakże wydaje mi się, że to nie zadziała. Szerokość section ma się
    zmieniać w zależności od obecności lub nie sekcji aside. A tu uzależniasz
    szerokość aside jeśli jest poprzedzona przez section lub nie jest. Czyli
    dokładnie w drugą stronę niż potrzebuję.

    Czyli leśli section + aside => section zmienia szerokość


  • 28. Data: 2012-02-27 23:14:02
    Temat: Re: CSS - problem z selektorem
    Od: Borys Pogoreło <b...@p...edu.leszno>

    Dnia Mon, 27 Feb 2012 22:32:03 +0100, Marek napisał(a):

    > Jednakże wydaje mi się, że to nie zadziała. Szerokość section ma się
    > zmieniać w zależności od obecności lub nie sekcji aside. A tu uzależniasz
    > szerokość aside jeśli jest poprzedzona przez section lub nie jest. Czyli
    > dokładnie w drugą stronę niż potrzebuję.

    To zmień kolejność i floatuj w drugą stronę, w czym problem?

    --
    Borys Pogoreło
    borys(#)leszno,edu,pl


  • 29. Data: 2012-02-28 09:21:29
    Temat: Re: CSS - problem z selektorem
    Od: Marek <p...@s...com>

    Dnia Tue, 28 Feb 2012 00:14:02 +0100, Borys Pogoreło napisał(a):

    > Dnia Mon, 27 Feb 2012 22:32:03 +0100, Marek napisał(a):
    >
    >> Jednakże wydaje mi się, że to nie zadziała. Szerokość section ma się
    >> zmieniać w zależności od obecności lub nie sekcji aside. A tu uzależniasz
    >> szerokość aside jeśli jest poprzedzona przez section lub nie jest. Czyli
    >> dokładnie w drugą stronę niż potrzebuję.
    >
    > To zmień kolejność i floatuj w drugą stronę, w czym problem?

    O rany. Doradziłeś mi (kolejne) rozwiązanie, ja znalazłem w nim mankament i
    go skomentowałem. Jordan zaproponował ciekawe rozwiązanie na bazie CSS bez
    dokonywania zmian w kodzie HTML. Więc temat jest zamknięty, co nie oznacza,
    że dalsze propozycje nie są dla mnie ciekawe. Mogą się przydać w
    przyszłości.


  • 30. Data: 2012-02-28 19:48:08
    Temat: Re: CSS - problem z selektorem
    Od: Borys Pogoreło <b...@p...edu.leszno>

    Dnia Tue, 28 Feb 2012 10:21:29 +0100, Marek napisał(a):

    >> To zmień kolejność i floatuj w drugą stronę, w czym problem?
    >
    > O rany. Doradziłeś mi (kolejne) rozwiązanie, ja znalazłem w nim mankament i
    > go skomentowałem. Jordan zaproponował ciekawe rozwiązanie na bazie CSS bez
    > dokonywania zmian w kodzie HTML. Więc temat jest zamknięty, (...)

    ... do czasu, aż nie będziesz potrzebował podobnego rozwiązania dla układu
    trzykolumnowego. Wtedy :last-child nie da rady (który też nie jest zbyt
    lubiany przez starsze wersje IE), a wersja z selektorem + bez problemu.

    --
    Borys Pogoreło
    borys(#)leszno,edu,pl

strony : 1 . 2 . [ 3 ] . 4


Szukaj w grupach

Szukaj w grupach

Eksperci egospodarka.pl

1 1 1

Wpisz nazwę miasta, dla którego chcesz znaleźć jednostkę ZUS.

Wzory dokumentów

Bezpłatne wzory dokumentów i formularzy.
Wyszukaj i pobierz za darmo: