Elm - Perintah

Pada bab sebelumnya, kita telah membahas berbagai komponen arsitektur Elm dan fungsinya. Pengguna dan aplikasi berkomunikasi satu sama lain menggunakan Message.

Pertimbangkan contoh, di mana aplikasi perlu berkomunikasi dengan komponen lain seperti server eksternal, API, layanan mikro, dll. Untuk melayani permintaan pengguna. Ini dapat dicapai dengan menggunakan Perintah di Elm. Pesan dan perintah tidak sama. Pesan mewakili komunikasi antara pengguna akhir dan aplikasi sementara perintah mewakili bagaimana aplikasi Elm berkomunikasi dengan entitas lain. Perintah dipicu sebagai tanggapan atas pesan.

Gambar berikut menunjukkan alur kerja aplikasi Elm yang kompleks -

Pengguna berinteraksi dengan tampilan. Tampilan menghasilkan pesan yang sesuai berdasarkan tindakan pengguna. Komponen pembaruan menerima pesan ini dan memicu perintah.

Sintaksis

Sintaks untuk mendefinisikan perintah seperti yang diberikan di bawah ini -

type Cmd msg

Pesan yang dihasilkan oleh view tersebut diteruskan ke perintah.

Ilustrasi

Contoh berikut membuat permintaan ke API dan menampilkan hasil dari API.

Aplikasi menerima nomor dari pengguna, meneruskannya ke Numbers API. API ini mengembalikan fakta terkait nomor tersebut.

Berbagai komponen aplikasi adalah sebagai berikut -

Modul Http

Modul Http Elm digunakan untuk membuat dan mengirim permintaan HTTP. Modul ini bukan merupakan bagian dari modul inti. Kami akan menggunakan manajer paket elm untuk menginstal paket ini.

API

Dalam contoh ini, aplikasi akan berkomunikasi dengan Numbers API - "http://numbersapi.com/#42".

Melihat

Tampilan aplikasi berisi kotak teks dan tombol.

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 mewakili nilai yang dimasukkan oleh pengguna dan hasil yang akan dikembalikan oleh API.

type alias Model =
   { heading : String
   , factText : String
   , input :String
   }

Pesan

Aplikasi ini memiliki tiga pesan berikut -

  • ShowFacts
  • Input
  • NewFactArrived

Setelah mengklik tombol Show Facts , pesan ShowFacts diteruskan ke metode update. Ketika pengguna mengetik beberapa nilai di kotak teks, pesan Input diteruskan ke metode pembaruan. Akhirnya, ketika respons server Http diterima, pesan NewFactArrived akan diteruskan ke pembaruan.

type Msg
   = ShowFacts
   |Input String
   | NewFactArrived (Result Http.Error String)

Memperbarui

Metode pembaruan mengembalikan tupel, yang berisi objek model dan perintah. Ketika pengguna mengklik tombol Tampilkan Fakta, Pesan diteruskan ke pembaruan yang kemudian memanggil 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)

Fungsi Pembantu

Fungsi pembantu getRandomNumberFromAPI memanggil NumbersAPI dan meneruskan nomor yang dimasukkan pengguna. Hasil yang dikembalikan oleh API digunakan untuk memperbarui model.

getRadmonNumberFromAPI : String->Cmd Msg
getRadmonNumberFromAPI newNo =
   let
      url =
         "http://numbersapi.com/"++newNo
   in
      Http.send NewFactArrived (Http.getString url)
No Sr metode Tanda tangan Deskripsi
1 Http.getString getString: String -> Permintaan String Buat permintaan GET dan tafsirkan isi respons sebagai String.
2 Http.send kirim: (Kesalahan Hasil a -> pesan) -> Minta a -> Cmd pesan Kirim permintaan Http.

utama

Ini adalah pintu masuk proyek Elm.

main =
   Html.program
      { init = init
      , view = view
      , update = update
      , subscriptions = subscriptions
      }

Menyatukan semuanya

Step 1 - Buat folder CommandApp dan file CommandDemo.elm.

Step 2- Instal modul http menggunakan perintah paket elm install elm-lang / http .

Step 2 - Ketik konten untuk CommandDemo.elm seperti yang ditunjukkan di bawah ini -

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 - Tembak perintahnya.

C:\Users\dell\elm\CommandApp> elm make .\CommandDemo.elm

Ini akan menghasilkan file html seperti yang ditunjukkan di bawah ini.