Elm-기본 구문

이 장에서는 elm에서 간단한 프로그램을 작성하는 방법에 대해 설명합니다.

Step 1 − Create a directory HelloApp in VSCode

이제 파일을 만듭니다. Hello.elm 이 디렉토리에서.

위 다이어그램은 프로젝트 폴더를 보여줍니다. HelloApp VSCode에서 열린 터미널.

Step 2 − Install the necessary elm packages

elm의 패키지 관리자는 elm-package 입니다. elm-lang / html 패키지를 설치하십시오 . 이 패키지는 브라우저에 elm 코드의 출력을 표시하는 데 도움이됩니다.

가로 질러 HelloApp 파일 → VSCode의 명령 프롬프트에서 열기를 마우스 오른쪽 버튼으로 클릭하여 프로젝트 폴더.

터미널 창에서 다음 명령을 실행하십시오-

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

패키지 설치시 다음 파일 / 폴더가 프로젝트 디렉토리에 추가됩니다.

  • elm-package.json (파일), 프로젝트 메타 데이터 저장
  • elm-stuff (폴더), 외부 패키지 저장

패키지가 성공적으로 설치되면 다음 메시지가 나타납니다.

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"

위의 프로그램은 문자열 메시지를 표시합니다 Hello Elm from TutorialsPoint 브라우저에서.

이를 위해 함수를 가져와야합니다. textHtml기준 치수. 텍스트 함수는 브라우저에서 문자열 값을 인쇄하는 데 사용됩니다. 주요 방법은 프로그램의 진입 점입니다. 주요 방법은 호출 텍스트 기능을하고 여기에 문자열 값을 전달합니다.

Step 4 − Compile the project

VSCode 터미널 창에서 다음 명령을 실행합니다.

elm make Hello.elm

위 명령의 출력은 다음과 같습니다.

//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

위의 명령은 index.html파일. elm 컴파일러는 .elm 파일을 JavaScript로 변환하고index.html 파일.

Step 5 − Open the index.html in the browser

브라우저에서 index.html 파일을 엽니 다 . 출력은 다음과 같습니다.

Elm의 댓글

주석은 프로그램의 가독성을 향상시키는 방법입니다. 주석은 코드 작성자, 함수 구조에 대한 힌트 등과 같은 프로그램에 대한 추가 정보를 포함하는 데 사용할 수 있습니다. 주석은 컴파일러에서 무시됩니다.

Elm은 다음 유형의 주석을 지원합니다.

  • 한 줄 주석 (-)--와 줄 끝 사이의 모든 텍스트는 주석으로 처리됩니다.

  • 여러 줄 주석 ({--})-이 주석은 여러 줄에 걸쳐있을 수 있습니다.

삽화

-- this is single line comment

{- This is a
   Multi-line comment
-}

줄과 들여 쓰기

Elm은 함수 정의 또는 흐름 제어를위한 코드 블록을 나타내는 중괄호를 제공하지 않습니다. 코드 블록은 엄격하게 적용되는 줄 들여 쓰기로 표시됩니다. 블록 내의 모든 문은 동일한 양으로 들여 쓰기되어야합니다. 예를 들면-

module ModuleIf exposing (..)
x = 0

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

그러나 다음 블록은 오류를 생성합니다.

-- 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"

따라서 Elm에서 동일한 수의 공백으로 들여 쓰기 된 모든 연속 행은 블록을 형성합니다.

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