एल्म - बेसिक सिंटेक्स

इस अध्याय में चर्चा की गई है कि एल्म में एक सरल कार्यक्रम कैसे लिखा जाए।

Step 1 − Create a directory HelloApp in VSCode

अब, एक फ़ाइल बनाएँ - Hello.elm इस निर्देशिका में।

उपरोक्त आरेख प्रोजेक्ट फ़ोल्डर दिखाता है HelloApp और टर्मिनल VSCode में खोला गया।

Step 2 − Install the necessary elm packages

एल्म में पैकेज प्रबंधक एल्म-पैकेज हैएल्म-लैंग / html पैकेज स्थापित करें । यह पैकेज हमें ब्राउज़र में एल्म कोड के आउटपुट को प्रदर्शित करने में मदद करेगा।

के लिए पार HelloApp फ़ाइल पर राइट क्लिक करके प्रोजेक्ट फोल्डर → VSCode में कमांड प्रॉम्प्ट में खोलें।

टर्मिनल विंडो में निम्न कमांड निष्पादित करें -

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

पैकेज स्थापित करने पर परियोजना निर्देशिका में निम्नलिखित फाइलें / फ़ोल्डर जोड़े जाते हैं।

  • elm-package.json (फ़ाइल), प्रोजेक्ट मेटा डेटा संग्रहीत करता है
  • एल्म-सामान (फ़ोल्डर), बाहरी पैकेज संग्रहीत करता है

पैकेज सफलतापूर्वक स्थापित होने के बाद निम्न संदेश दिखाई देगा।

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 ब्राउज़र में।

इसके लिए, हमें फ़ंक्शन को आयात करने की आवश्यकता है text के अंदर Htmlमापांक। पाठ फ़ंक्शन का उपयोग ब्राउज़र में किसी भी स्ट्रिंग मान को प्रिंट करने के लिए किया जाता है। मुख्य विधि एक कार्यक्रम के लिए प्रवेश बिंदु है। मुख्य विधि invokes पाठ समारोह और इसे करने के लिए एक स्ट्रिंग मान से गुजरता है।

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 फ़ाइल को जावास्क्रिप्ट में कनवर्ट करता है और इसे अंदर एम्बेड करता हैindex.html फ़ाइल।

Step 5 − Open the index.html in the browser

किसी भी ब्राउज़र में index.html फ़ाइल खोलें । आउटपुट नीचे दिखाया गया है -

एल्म में टिप्पणियाँ

टिप्पणियाँ एक कार्यक्रम की पठनीयता में सुधार करने का एक तरीका है। किसी प्रोग्राम के बारे में अतिरिक्त जानकारी शामिल करने के लिए टिप्पणियों का उपयोग किया जा सकता है जैसे कि कोड के लेखक, एक फ़ंक्शन निर्माण के बारे में संकेत, आदि टिप्पणियाँ संकलक द्वारा अनदेखा की जाती हैं।

एल्म निम्नलिखित प्रकार की टिप्पणियों का समर्थन करता है -

  • एकल-पंक्ति टिप्पणियाँ (-) - एक पंक्ति के अंत और उसके बीच के किसी भी पाठ को एक टिप्पणी के रूप में माना जाता है।

  • मल्टी-लाइन टिप्पणियां ({- -}) - इन टिप्पणियों में कई लाइनें हो सकती हैं।

चित्रण

-- this is single line comment

{- This is a
   Multi-line comment
-}

रेखाएँ और संकेत

एल्म फ़ंक्शन परिभाषाओं या प्रवाह नियंत्रण के लिए कोड के ब्लॉक को इंगित करने के लिए कोई ब्रेसिज़ प्रदान नहीं करता है। कोड के खंडों को लाइन इंडेंटेशन द्वारा दर्शाया जाता है, जिसे सख्ती से लागू किया जाता है। एक ब्लॉक के भीतर सभी विवरणों को समान राशि का इंडेंट किया जाना चाहिए। उदाहरण के लिए -

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"

इस प्रकार, एल्म में सभी समान लाइनों के साथ समान संख्या में रिक्त स्थान एक ब्लॉक का निर्माण करेगा।

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