• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Ocena webaplikacji (vue.js)

Object Storage Arubacloud
+2 głosów
472 wizyt
pytanie zadane 13 czerwca 2019 w Rozwój zawodowy, nauka, praca przez m4sk1n Pasjonat (16,750 p.)
Witam,

Od jakiegoś czasu skupiłem swoją naukę programowania na JavaScripcie i chciałbym dowiedzieć się, jak mi to wychodzi pod względem stosowania się do dobrych praktyk itd. Jako przykład pokażę niedawno ukończoną aplikację webową pomagającą w nauce na pamięć dłuższych tekstów. Wykorzystałem Vue.js, vue-router, vuex i vuetify, na logika aplikacji jest napisana w TypeScript (trochę niepotrzebnie dzieliłem front-end od reszty)

Wydaje mi się, że idzie mi to słabo, ale muszę przestać wstydzić się swojego kodu i zacząć prosić o feedback…

Aplikacja (jeszcze nie ma sensownej nazwy ani ikony): https://yutla.mkljczk.pl

Kod źródłowy: https://github.com/m4sk1n/yet-unnamed-text-learning-app

1 odpowiedź

+1 głos
odpowiedź 13 czerwca 2019 przez niezalogowany
wybrane 19 czerwca 2019 przez m4sk1n
 
Najlepsza

Jeśli chodzi o vue, praktycznie wzorcowo napisany kod według dokumentacji. Dobra robota! Kilka rzeczy złapałem

1. Niepotrzebnie tworzysz gettery. Jeśli potrzebujesz odczytać dane ze state'u, odczytaj je bezpośrednio. Gettery to takie computed dla stora

2. Nie nadpisuj natywnych obiektów (Error)

import Error from '@/components/Error';

3. Miejscami brakuje scoped w css-ach, Warto dodawać, żeby później się nie denderwować

4. Niepotrzebnie rzutujesz na booleana

:light="!!error && darkMode"

operator sam sobie zrzutuje

5. Eslint albo IDE powinno Ci wychwytywać takie  "Błędy"

 let answer = [];
 for (const index in this.answer) {
    if (!this.answer[index][0]) answer[index] = this.text[index];
    else answer[index] = this.answer[index][0];
}
this.error = this.session.check(answer.join(' '));

const answer, zamiast let

6. Nie musisz wywoływać metod w templatkach, wystarczy, że podasz referencje

<v-btn icon dark @click="dismiss()">

@click="dismiss">

7. Preferowany rodzaj komunikacji z parentem to $emit

props: {
  dismiss: Function,
 }

Zwiększa to czytelność i reużywalność komponentów

8. Nie rozumiem po co tutaj

const state = {
  courseList: [],
  courses: {},
};

hash table i zwykla lista, imo dużo zamieszania jest w tym module

komentarz 13 czerwca 2019 przez m4sk1n Pasjonat (16,750 p.)

2. Error to trochę zła nazwa dla tego komponentu poza tym…

4. Musiałem mieć jakiś powód skoro to zrobiłem, takie rzeczy sprawiają że wstydzę się swojego kodu :D pewnie wcześniej warunek był odwrotny

5. W pewnym momencie wyłączyłem eslinta i zapomniałem o włączeniu go w ogóle…

8. Jedno na informacje o kursie, drugie na jego zawartość. Powinienem to zmienić w momencie, gdy kolejność na liście przestała być taka, jak w tablicy…

Dziękuję bardzo za te uwagi :)

Podobne pytania

+1 głos
1 odpowiedź 169 wizyt
pytanie zadane 16 stycznia 2023 w JavaScript przez mi-20 Stary wyjadacz (13,190 p.)
0 głosów
1 odpowiedź 152 wizyt
pytanie zadane 27 czerwca 2021 w JavaScript przez mikey Użytkownik (820 p.)
+1 głos
2 odpowiedzi 384 wizyt
pytanie zadane 19 kwietnia 2021 w JavaScript przez mi-20 Stary wyjadacz (13,190 p.)

92,551 zapytań

141,393 odpowiedzi

319,523 komentarzy

61,936 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...