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.