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