Wiąz - Polecenia
W poprzednich rozdziałach omówiliśmy różne elementy architektury wiązu i ich funkcje. Użytkownik i aplikacja komunikują się ze sobą za pomocą Wiadomości.
Rozważmy przykład, w którym aplikacja musi komunikować się z innymi składnikami, takimi jak serwer zewnętrzny, interfejsy API, mikrousługa itp., Aby obsłużyć żądanie użytkownika. Można to osiągnąć za pomocą poleceń w wiązie. Wiadomości i polecenia nie są synonimami. Wiadomości reprezentują komunikację między użytkownikiem końcowym a aplikacją, podczas gdy polecenia reprezentują sposób, w jaki aplikacja Elm komunikuje się z innymi jednostkami. Polecenie jest wyzwalane w odpowiedzi na wiadomość.
Poniższy rysunek przedstawia przepływ pracy złożonej aplikacji Elm -
Użytkownik wchodzi w interakcję z widokiem. Widok generuje odpowiedni komunikat na podstawie akcji użytkownika. Komponent aktualizacji otrzymuje ten komunikat i uruchamia polecenie.
Składnia
Składnia definiowania polecenia jest następująca:
type Cmd msg
Wiadomość wygenerowana przez widok jest przekazywana do polecenia.
Ilustracja
Poniższy przykład wysyła żądanie do interfejsu API i wyświetla wynik z interfejsu API.
Aplikacja przyjmuje numer od użytkownika i przekazuje go do Numbers API. Ten interfejs API zwraca fakty związane z liczbą.
Różne elementy aplikacji są następujące -
Moduł HTTP
Moduł HTTP firmy Elm służy do tworzenia i wysyłania żądań HTTP. Ten moduł nie jest częścią modułu podstawowego. Do zainstalowania tego pakietu użyjemy menedżera pakietów elm.
API
W tym przykładzie aplikacja będzie komunikować się z interfejsem API Numbers - „http://numbersapi.com/#42”.
Widok
Widok aplikacji zawiera pole tekstowe i przycisk.
view : Model -> Html Msg
view model =
div []
[ h2 [] [text model.heading]
,input [onInput Input, value model.input] []
, button [ onClick ShowFacts ] [ text "show facts" ]
, br [] []
, h3 [][text model.factText]
]
Model
Model reprezentuje wartość wprowadzoną przez użytkownika i wynik, który zostanie zwrócony przez interfejs API.
type alias Model =
{ heading : String
, factText : String
, input :String
}
Wiadomość
Aplikacja zawiera następujące trzy komunikaty -
- ShowFacts
- Input
- NewFactArrived
Po kliknięciu Pokaż Fakty przycisku ShowFacts wiadomość jest przekazywana do metody aktualizacji. Gdy użytkownik wpisze jakąś wartość w polu tekstowym, komunikat wejściowy jest przekazywany do metody aktualizacji. Na koniec, po odebraniu odpowiedzi serwera Http, wiadomość NewFactArrived zostanie przekazana do aktualizacji.
type Msg
= ShowFacts
|Input String
| NewFactArrived (Result Http.Error String)
Aktualizacja
Metoda update zwraca krotkę, która zawiera model i obiekty poleceń. Gdy użytkownik kliknie przycisk Pokaż fakty, komunikat jest przekazywany do aktualizacji, która następnie wywołuje interfejs NumbersAPI.
update : Msg -> Model -> (Model, Cmd Msg)
update msg model =
case msg of
Input newInput ->
(Model "NumbersApi typing.." "" newInput ,Cmd.none)
ShowFacts ->
(model, getRadmonNumberFromAPI model.input)
NewFactArrived (Ok newFact) ->
(Model "DataArrived" newFact "", Cmd.none)
NewFactArrived (Err _) ->
(model, Cmd.none)
Funkcja pomocnika
Funkcja pomocnicza getRandomNumberFromAPI wywołuje NumbersAPI i przekazuje do niego liczbę wprowadzoną przez użytkownika. Wynik zwracany przez API jest używany do aktualizacji modelu.
getRadmonNumberFromAPI : String->Cmd Msg
getRadmonNumberFromAPI newNo =
let
url =
"http://numbersapi.com/"++newNo
in
Http.send NewFactArrived (Http.getString url)
Sr. No. | metoda | Podpis | Opis |
---|---|---|---|
1 | Http.getString | getString: String -> Ciąg żądania | Utwórz żądanie GET i zinterpretuj treść odpowiedzi jako ciąg. |
2 | Http.send | send: (Błąd wyniku a -> msg) -> Żądanie a -> Cmd msg | Wyślij żądanie HTTP. |
Główny
To jest punkt wyjścia do projektu Elm.
main =
Html.program
{ init = init
, view = view
, update = update
, subscriptions = subscriptions
}
Kładąc wszystko razem
Step 1 - Utwórz folder CommandApp i plik CommandDemo.elm.
Step 2- Zainstaluj moduł http za pomocą polecenia elm package install elm-lang / http .
Step 2 - Wpisz zawartość CommandDemo.elm, jak pokazano poniżej -
import Html exposing (..)
import Html.Attributes exposing (..)
import Html.Events exposing (..)
import Http
main =
Html.program
{ init = init
, view = view
, update = update
, subscriptions = subscriptions
}
-- MODEL
type alias Model =
{ heading : String
, factText : String
, input :String
}
init : (Model, Cmd Msg)
init =
( Model "NumbersAPI" "NoFacts" "42"-- set model two fields
, Cmd.none -- not to invoke api initially
)
-- UPDATE
type Msg
= ShowFacts
|Input String
| NewFactArrived (Result Http.Error String)
update : Msg -> Model -> (Model, Cmd Msg)
update msg model =
case msg of
Input newInput ->
(Model "NumbersApi typing.." "" newInput ,Cmd.none)
ShowFacts ->
(model, getRadmonNumberFromAPI model.input)
NewFactArrived (Ok newFact) ->
(Model "DataArrived" newFact "", Cmd.none)
NewFactArrived (Err _) ->
(model, Cmd.none)
- VIEW
view : Model -> Html Msg
view model =
div []
[ h2 [] [text model.heading]
,input [onInput Input, value model.input] []
, button [ onClick ShowFacts ] [ text "show facts" ]
, br [] []
, h3 [][text model.factText]
]
-- SUBSCRIPTIONS
subscriptions : Model -> Sub Msg
subscriptions model =
Sub.none
-- HTTP
getRadmonNumberFromAPI : String->Cmd Msg
getRadmonNumberFromAPI newNo =
let
url =
"http://numbersapi.com/"++newNo
in
Http.send NewFactArrived (Http.getString url)
Step 4 - Wystrzel komendę.
C:\Users\dell\elm\CommandApp> elm make .\CommandDemo.elm
Spowoduje to wygenerowanie pliku html, jak pokazano poniżej.