Wiąz - Architektura
W tym rozdziale omówimy standardowy sposób tworzenia aplikacji na platformie Elm. Elm używa wzorca architektonicznego podobnego do wzorca Model-View-Controller.
Poniżej znajdują się cztery główne części Architektury Wiązów.
- Model
- View
- Message
- Update
Jak działa architektura Elm
Plik modelzawiera stan aplikacji. Na przykład, jeśli aplikacja wyświetla listę klientów, stan będzie zawierał dane każdego klienta. Aby wyświetlić stan w reprezentacyjny sposób, aview/ html musi zostać wygenerowany. Gdy użytkownik wejdzie w interakcję z widokiem, naciskając przycisk lub wpisując dane w formularzu, widok generuje sygnały o nazwiemessages. Wiadomości są przekazywane doupdatemetoda, która ocenia komunikaty i podejmuje odpowiednie działania. Dlatego metoda aktualizacji wygeneruje nowy model.
Nowy model generuje nowy widok. Widok doprowadzi do nowych interakcji od użytkownika do komunikatów sygnalizacyjnych, które trafią do funkcji aktualizacji. Ponadto funkcja tworzy nowy model. Tak więc cykl powtarza się, jak pokazano na powyższym schemacie.
Model
Model dotyczy stanu aplikacji. Składnia definiowania modelu jest podana poniżej -
-- Model syntax
type alias Model = {
property1:datatype,
proptery2:datatype
...
}
Aby stworzyć model, musimy najpierw stworzyć szablon ze wszystkimi wymaganymi właściwościami. Każda właściwość określa stan aplikacji.
Widok
Widok to wizualna reprezentacja stanu aplikacji. The View wie, jak pobrać dane i wygenerować z nich stronę internetową. Gdy użytkownik wchodzi w interakcję z widokiem, może manipulować stanem, generując komunikaty. Składnia definiowania widoku jest podana poniżej -
--View Syntax
view model =some_implementation
Wiadomość
Komunikat to żądanie od użytkownika zmiany stanu aplikacji. Komunikaty są przekazywane jako parametr do funkcji aktualizacji.
--Message Syntax
type Message = Message1 |Message2 ...
Składnia przedstawia typ Message. Aplikacja elm będzie edytować stan na podstawie przekazanych do niej wiadomości. Decyzje te podejmowane są w metodzie aktualizacji.
Aktualizacja
Funkcja update interpretuje komunikaty, które są do niej przekazywane jako parametr, i aktualizuje model.
--Update Syntax
update Message_type model =
some_implementation
Funkcja aktualizacji trwa Message i Modeluj jako parametry.