Elm - podstawowa składnia

Ten rozdział omawia, jak napisać prosty program w elm.

Step 1 − Create a directory HelloApp in VSCode

Teraz utwórz plik - Hello.elm w tym katalogu.

Powyższy diagram przedstawia folder projektu HelloApp i terminal otwarty w VSCode.

Step 2 − Install the necessary elm packages

Menedżer pakietów w elm to elm-package . Zainstaluj pakiet elm-lang / html . Ten pakiet pomoże nam wyświetlić wyjście kodu elm w przeglądarce.

Przejdź do HelloApp folder projektu, klikając prawym przyciskiem myszy Plik → Otwórz w wierszu polecenia w VSCode.

Wykonaj następujące polecenie w oknie terminala -

C:\Users\dell\Elm\HelloApp> elm-package install elm-lang/html

Następujące pliki / foldery są dodawane do katalogu projektu podczas instalacji pakietu.

  • elm-package.json (plik), przechowuje metadane projektu
  • elm-stuff (folder), przechowuje pakiety zewnętrzne

Po pomyślnym zainstalowaniu pakietu pojawi się następujący komunikat.

Step 3 − Add the following code to the Hello.elm file

-- importing Html module and the function text
import Html exposing (text)

-- create main method
main =
-- invoke text function
text "Hello Elm from TutorialsPoint"

Powyższy program wyświetli komunikat tekstowy Hello Elm from TutorialsPoint w przeglądarce.

W tym celu musimy zaimportować funkcję text w ramach Htmlmoduł. Funkcja tekstowa służy do drukowania dowolnej wartości ciągu w przeglądarce. Główną metodą jest punkt wejścia do programu. Metoda main wywołuje funkcję tekstową i przekazuje do niej wartość ciągu.

Step 4 − Compile the project

Wykonaj następujące polecenie w oknie terminala VSCode.

elm make Hello.elm

Dane wyjściowe powyższego polecenia są pokazane poniżej -

//update path to the proj folder in the command elm make
C:\Users\dell\elm\HelloApp>elm make Hello.elm
Success! Compiled 38 modules.
Successfully generated index.html

Powyższe polecenie wygeneruje plik index.htmlplik. Kompilator elm konwertuje plik .elm do JavaScript i osadza go windex.html plik.

Step 5 − Open the index.html in the browser

Otwórz plik index.html w dowolnej przeglądarce. Wynik będzie taki, jak pokazano poniżej -

Komentarze w Elm

Komentarze są sposobem na poprawę czytelności programu. Komentarze mogą służyć do dołączania dodatkowych informacji o programie, takich jak autor kodu, wskazówki dotyczące konstrukcji funkcji itp. Komentarze są ignorowane przez kompilator.

Elm obsługuje następujące typy komentarzy -

  • Komentarze jednowierszowe (-) - dowolny tekst między znakiem - a końcem wiersza jest traktowany jako komentarz.

  • Komentarze wieloliniowe ({- -}) - te komentarze mogą obejmować wiele wierszy.

Ilustracja

-- this is single line comment

{- This is a
   Multi-line comment
-}

Linie i wcięcia

Elm nie zawiera nawiasów klamrowych wskazujących bloki kodu dla definicji funkcji lub kontroli przepływu. Bloki kodu są oznaczone wcięciami linii, które są sztywno wymuszane. Wszystkie instrukcje w bloku muszą mieć wcięcie tej samej wielkości. Na przykład -

module ModuleIf exposing (..)
x = 0

function1 =
   if x > 5 then
      "x is greater"
   else
      "x is small"

Jednak następujący blok generuje błąd -

-- Create file ModuleIf.elm
module ModuleIf exposing (..)
x = 0

function1 =
   if x > 5 then
      "x is greater"
         else --Error:else indentation not at same level of if statement
      "x is small"

Zatem w Elm wszystkie ciągłe linie wcięte z taką samą liczbą spacji utworzyłyby blok.

C:\Users\admin>elm repl
---- elm-repl 0.18.0 -----------------------------------------------------------
   :help for help, :exit to exit, more at 
   <https://github.com/elm-lang/elm-repl>
   ---------------------------------------
   -----------------------------------------

> import ModuleIf exposing(..) -- importing module from ModuleIf.elm file
>function1 -- executing function from module
-- SYNTAX PROBLEM ---------------------------------------------------

I need whitespace, but got stuck on what looks like a new declaration. 
You are either missing some stuff in the declaration above or just need to add some spaces here:
7| else
   ^
I am looking for one of the following things:

   whitespace