17 Lip 2019

Numerowanie rekordów za pomocą CSS

Przejdźmy od razu do rzeczy, chciałbym aby w liście li znajdowała się cyfra, zwykła numeracja. Nie zrobimy tego w js, php tylko w czystym css.

<ul>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
  <li>lista</li>
</ul>

Użyjemy css

ul {
  list-style: none;
  counter-reset: section;
}

li:before {
  padding-right: 10px;
  counter-increment: section;
  content: counter(section);
}
30 Cze 2019

RGB na HEX

Oczywiście poprzednio było HEX na RGB to oczywiście logiczne jest aby też podać i konwersję w drugą stronę 😉

function rgbToHex(rgb) {
  let hex = Number(rgb).toString(16);
  if(hex.length < 2) {
    hex = '0' + hex;
  }
  return hex;
}

function colorHex(r,g,b) {
  return rgbToHex(r) + rgbToHex(g) + rgbToHex(b);
}

A wywołanie to zwyczajne przekazanie funkcji trzech liczb na które składa się kolot rgb(0, 161, 255).

console.log(colorHex(0, 161,255));
// => w wyniku otrzymujemy #00a1ff
25 Cze 2019

HEX na RGB

Teraz coś małego ale jakże przydatnego. Konwersja HEX koloru np. #00a1ff na RGB.

function hexTorgb(fullhex) {
  const hex = fullhex.substring(1,7);
  return {
    R: parseInt(hex.substring(0,2), 16),
    G: parseInt(hex.substring(2,4), 16),
    B: parseInt(hex.substring(4,6), 16)
  }
}

A wywołanie to zwyczajne przekazanie stringa do funkcji.

console.log(hexTorgb('#00a1ff'));
// => {R: 0, G: 161, B: 255 } w wyniku mamy obiekt

Oczywiście nic nie stoi na przeszkodzie aby modyfikować tą funkcję.

4 Cze 2019

Czy justować tekst na stronie www?

Od razu odpowiem – NIE JUSTUJE SIĘ TEKSTU na stronach www.
Już tłumaczę dla czego, tego nie powinno się robić.

Obecnie wszystkie strony powinny być RWD (responsive web design), czyli najprościej tłumacząc szerokość stron jak i elementy stron dostosowują się do urządzeń automatycznie.
Justify bardzo dobrze się sprawdzało jeszcze kilka lat temu gdy nikt nie wiedział co to RWD i strony budowało się na szkielecie ‚table’ ach te czasy 😉

Tak jak w książce czy czasopiśmie mogliśmy łamać tekst dowolnie, aby to ładnie wyglądało, przenosić spójnik i przyimki do nowej linii, tak teraz jest to niemożliwe. Bo jeżeli wstawimy nową linię to po zmniejszeniu strony może się okazać i na pewno się okaże że koniec zdania wypadnie nam na środku strony, a chyba o to nam nie chodzi.

Budując strony staramy się aby tekst był dynamiczny, a dokładnie aby czcionka lub jak kto woli font 😉 zmieniała wielkość w zależności od szerokości strony. Zakłada się, że czcionka powinna mieć minimalnie 16px.
Poniżej umieściłem przykład tego jak źle wygląda tekst, który posiada 2 kolumny i jest justowany.

Czy widzieliście takie odstępy w książce czy czasopiśmie, na pewno nie. Wygląda to źle i bardzo męczy wzrok przy dłuższym czytaniu.

Przy budowaniu strony powinniśmy zwrócić na kilka istotnych elementów wpływający na komfort czytania.
Wypunktuję może kilka z nich i opiszę dla czego to takie ważne.

Wybieramy odpowiednią czcionkę.

Niestety ale urządzenia na których czytamy w większości mają powłokę błyszczącą, czytamy w słońcu, w ciemnym pomieszczeniu itp. Więc czcionka powinna być czytelna, nie tylko wielkość ale także kolor i krój ma znaczenie.
Na szczęście coraz rzadziej ale nadal się zdarza że „domorośli graficy” nie tylko używają po 10 różnych rodzajów czcionek, ale także czasami używają czcionki do których potrzebna jest licencja i to dość droga bo o tym oczywiście nie wiedzą 🙂

Rozmiar ma znaczenie

Czcionka którą wybierzemy musi być czytelna, odpowiednio dobrana wielkość czcionki to rozdzielczości ekranu. Tak jak wyżej pisałem 16px obecnie to minimum.
W jednym wierszu powinno być około 50-80 znaków. Szerokość elementów z tekstem to maksymalnie 960px. Oczywiście to tylko zalecenia.

Interlinia

Równie ważną rzeczą jest interlinia czyli odstęp między wierszami. Zależna jest ona od wielkości czcionki, rodzaju itp. Najlepiej jak by interlinia zmieniała się wraz z wielkością czcionki przy zmienianiu szerokości strony. Do tego możne użyć [ kalkulatorów online ] gdzie podajemy szerokość strony, rodzaj czcionki i font-size. W wyniku otrzymujemy line-height czyli interlinię.

Kontrast

Czcionka powinna być czytelna, tak samo jak kolor tła powinien być odpowiednio dobrany, tak aby czytanie nie męczyło nam wzroku.
Czasami możemy dodać możliwość zmiany koloru tła a wraz z nim koloru czcionki. Np. na youtube można ustawić kolor strony na ciemny. Warto sprawdzić czy użycie kolorów czcionki i tła jest odpowiednie, można to sprawdzić np. na tej [ stronie ]

To tylko kilka zasad którymi się kieruję przy projektowaniu strony. Oczywiście każdym ma swoje podejście do tego, ale sądzę że to najważniejsze elementy, które należy uwzględnić.
Nic tak nie drażni jak powiększanie strony, aby móc ją przeczytać 😉

28 Maj 2019

Dynamiczne ładowanie plików JavaScript

Większość użytkowników ma określony cel przeglądając witrynę. Na przykład jeden użytkownik może chcieć przeglądać katalog produktów tylko po to, aby zobaczyć, co masz w sklepie. Nie jest mu potrzebny kod js w zakładce „pokaż recenzje” bo tam po prostu nie trafi. Więc serwowanie kodu z całej witryny mija się z celem.

Jeżeli chcesz tworzyć szybkie witryny, musisz przesłać jak najmniej JavaScript do przeglądarek. Pobieranie pakietu JavaScript wymaga nie tylko czasu, ale przeglądarka musi także wyodrębnić kod i przeanalizować go, co również zajmuje dużo czasu.

Powolne działanie witryny sprawia, że użytkownicy odchodzą, optymalny czas ładowania strony to maksymalnie 2-3s. Takie podejście serwowania kodu w małych paczkach jest również dobre dla SEO – Google bardzo lubi szybkie strony ;).

To co powinieneś zrobić, to wysłać tyko JavaScript, którego użytkownik potrzebuje do przeglądania i interakcji z odwiedzanymi stronami. W ten sposób witryna ładuje się znacznie szybciej.

Takie ładowanie możemy przygotować za pomocą webpacka i dynamicznego ładowania.

Gdy korzystasz z importu dynamicznego, wstawiasz minimalną ilość javascirpt na stronie i ładujesz resztę dynamicznie, gdy i jeśli użytkownik tego potrzebuje.

Nasz przykład będzie bardzo prosty, na środku strony będzie znajdował się przycisk po kliknięciu którego zmienimy kolor tła strony. Kliknięcie spowoduje załadowanie pliku js który to właśnie zmieni nam to tło.

Jak skonfigurować dynamiczny import pakietów internetowych w webpack

Zacznijmy od webpacka. Mam nadzieję że wiesz jak instalować pakiety npm?. Masz zainstalowane node?. Jeśli nie, no cóż, może kiedyś powstanie jakiś artykuł. Na obecną chwilę polecam [ artykuł ].

Inicjalizacja projektu. Ja używam yarn, oczywiście nic nie stoi na przeszkodzie użycie npm.

yarn init -y