Elm - Guide rapide

Elm est un langage de programmation fonctionnel. Il a été conçu par Evan Czaplicki en 2012.

Elm est spécifiquement utilisé pour la conception de front-end d'applications Web.

Elm compile en JavaScript et s'exécute dans le navigateur. Il est rapide, testable, maintenable et est livré sans exception d'exécution.

Certaines applications pratiques de la plate-forme de programmation Elm comprennent:

  • Games
  • Graphics
  • Applications sur une seule page

Pourquoi Elm

Elm élimine la plupart des problèmes courants rencontrés par les développeurs frontend. Cela comprend -

Aucune exception d'exécution

Elm est un langage typé statiquement. Toutes les erreurs possibles sont validées et corrigées au moment de la compilation. Cela permet de ne pas avoir d'exceptions d'exécution.

Messages d'erreur conviviaux pour les développeurs

Contrairement à d'autres langages de programmation, le compilateur d'Elm est conçu pour fournir des messages d'erreur très spécifiques et conviviaux pour les développeurs au moment de la compilation. Les messages d'erreur incluent également des conseils tels que des liens vers des documentations de conception recommandées.

Facile à tester

Chaque fonction Elm peut être testée indépendamment de toutes les autres. Cela rend les programmes écrits en Elm facilement testables.

Versionnage sémantique automatique

Elm applique le contrôle de version sémantique automatique des packages. Cela garantit qu'une modification de correctif ne plante pas une application déjà en cours d'exécution.

Code réutilisable

Les fonctions Elm sont intrinsèquement faciles à réutiliser par rapport aux fonctions en JavaScript, Python ou TypeScript.

Ce chapitre décrit les étapes d'installation d'Elm sur les plates-formes Windows, Mac et Linux.

Configuration de l'environnement local

Suivez les étapes ci-dessous pour installer Elm dans votre environnement local.

Step 1 − Install node

Comme elm est compilé en JavaScript, la machine cible doit avoir nodeinstallée. Reportez-vous au cours TutorialsPoint NodeJS pour les étapes de configurationnode et npm

Configuration du nœud.

Step 2 − Install elm

Exécutez la commande suivante sur le terminal pour installer elm. Notez que la version stable d'elm était de 0,18 au moment de la rédaction de ce cours.

npm install -g [email protected]

Après l'installation, exécutez la commande suivante pour vérifier la version d'Elm.

C:\Users\dell>elm --version
0.18.0

Step 2 − Install the Editor

L'environnement de développement utilisé ici est Visual Studio Code (plateforme Windows).

Visual Studio Code est un IDE open source de Visual Studio. Il est disponible pour les plates-formes Mac OS X, Linux et Windows. VSCode est disponible sur

Installation sous Windows

Dans cette section, nous discuterons des étapes d'installation d'Elm sous Windows.

Télécharger https://code.visualstudio.com/. Pour les fenêtres.

Double-cliquez sur VSCodeSetup.exe pour lancer le processus d'installation. Cela ne prendra qu'une minute.

Vous pouvez accéder directement au chemin du fichier en cliquant avec le bouton droit sur Fichier → Ouvrir dans l'invite de commande. De même, l'option Révéler dans l'Explorateur affiche le fichier dans l'Explorateur de fichiers.

Installation sous Mac OS X

Le guide d'installation spécifique à Mac OS X de Visual Studio Code est disponible à l'adresse Installation VSCode-MAC.

Installation sous Linux

Le guide d'installation spécifique à Linux de Visual Studio Code est disponible à l'adresse Installation de VSCode-Linux.

Step 4 − Install the elm Extension

Installez l'extension elm dans VSCode comme indiqué ci-dessous.

Elm REPL

REPL signifie Read Eval Print Loop. Il représente un environnement informatique comme une console Windows ou un shell Unix / Linux où une commande est entrée et le système répond avec une sortie en mode interactif.

Elm est livré avec un environnement REPL. Il effectue les tâches suivantes -

  • Lire - Lit l'entrée de l'utilisateur, analyse l'entrée dans la structure de données elm et stocke en mémoire.

  • Eval - Prend et évalue la structure de données.

  • Imprimer - Imprime le résultat.

  • Boucle: boucle la commande ci-dessus jusqu'à ce que l'utilisateur quitte. Utilisez la commande: exit pour quitter REPL et revenir au terminal.

Un exemple simple pour ajouter deux nombres dans REPL est montré ci-dessous -

Ouvrez le terminal VSCode et tapez la commande elm REPL.

Le terminal REPL attend que l'utilisateur entre une entrée. Entrez l'expression suivante 10 + 20. L'environnement REPL traite l'entrée comme indiqué ci-dessous -

  • Lit les numéros 10 et 20 de l'utilisateur.

  • Évalue à l'aide de l'opérateur +.

  • Les impressions donnent 30.

  • Boucles pour la prochaine entrée utilisateur. Ici, nous sortons de la boucle.

Ce chapitre explique comment écrire un programme simple dans elm.

Step 1 − Create a directory HelloApp in VSCode

Maintenant, créez un fichier - Hello.elm dans ce répertoire.

Le diagramme ci-dessus montre le dossier du projet HelloApp et terminal ouvert en VSCode.

Step 2 − Install the necessary elm packages

Le gestionnaire de packages dans elm est elm-package . Installez le package elm-lang / html . Ce package nous aidera à afficher la sortie du code elm dans le navigateur.

Traverser vers le HelloApp dossier du projet en faisant un clic droit sur Fichier → Ouvrir dans l'invite de commande dans VSCode.

Exécutez la commande suivante dans la fenêtre du terminal -

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

Les fichiers / dossiers suivants sont ajoutés au répertoire du projet lors de l'installation du package.

  • elm-package.json (fichier), stocke les métadonnées du projet
  • elm-stuff (dossier), stocke les packages externes

Le message suivant apparaîtra une fois le package installé avec succès.

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"

Le programme ci-dessus affichera un message de chaîne Hello Elm from TutorialsPoint dans le navigateur.

Pour cela, nous devons importer la fonction text dans le Htmlmodule. La fonction de texte est utilisée pour imprimer toute valeur de chaîne dans le navigateur. La méthode principale est le point d'entrée d'un programme. La méthode main appelle la fonction de texte et lui transmet une valeur de chaîne.

Step 4 − Compile the project

Exécutez la commande suivante dans la fenêtre du terminal VSCode.

elm make Hello.elm

La sortie de la commande ci-dessus est comme indiqué ci-dessous -

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

La commande ci-dessus générera un index.htmlfichier. Le compilateur elm convertit le fichier .elm en JavaScript et l'incorpore dans leindex.html fichier.

Step 5 − Open the index.html in the browser

Ouvrez le fichier index.html dans n'importe quel navigateur. La sortie sera comme indiqué ci-dessous -

Commentaires dans Elm

Les commentaires sont un moyen d'améliorer la lisibilité d'un programme. Les commentaires peuvent être utilisés pour inclure des informations supplémentaires sur un programme comme l'auteur du code, des conseils sur une construction de fonction, etc. Les commentaires sont ignorés par le compilateur.

Elm prend en charge les types de commentaires suivants -

  • Commentaires sur une seule ligne (-) - Tout texte entre un - et la fin d'une ligne est traité comme un commentaire.

  • Commentaires sur plusieurs lignes ({- -}) - Ces commentaires peuvent s'étendre sur plusieurs lignes.

Illustration

-- this is single line comment

{- This is a
   Multi-line comment
-}

Lignes et retrait

Elm ne fournit pas d'accolades pour indiquer des blocs de code pour les définitions de fonction ou le contrôle de flux. Les blocs de code sont indiqués par une indentation de ligne, qui est appliquée de manière rigide. Toutes les instructions dans un bloc doivent être indentées du même montant. Par exemple -

module ModuleIf exposing (..)
x = 0

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

Cependant, le bloc suivant génère une erreur -

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

Ainsi, dans Elm, toutes les lignes continues indentées avec le même nombre d'espaces formeraient un bloc.

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

Le système de types représente les différents types de valeurs pris en charge par la langue. Le système de types vérifie la validité des valeurs fournies avant qu'elles ne soient stockées ou manipulées par le programme. Cela garantit que le code se comporte comme prévu. Le système de types permet en outre des indications de code plus riches et une documentation automatisée.

Elm est un langage typé statiquement. Elm a des types similaires à ceux d'autres langues.

Nombre

Le nombre type de données représente des valeurs numériques. Le système de type Elm prend en charge les types numériques suivants -

Sr. No. Type Exemple
1 number - Stocke n'importe quel nombre 7 est le type de nombre
2 Float - Stocke les valeurs fractionnaires 7/2 donne 3,5 résultat comme Float
3 Int - Stocke les valeurs non fractionnaires 7 // 2 donne 3 résultat comme Int

Le numéro de type accepte les valeurs fractionnaires et non fractionnaires. Ouvrez le REPL elm et essayez les exemples ci-dessous -

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>
------------------------------------------
--------------------------------------
> 7
7 : number
> 7/2
3.5 : Float
> 7//2
3 : Int
>

String and Char

The String data type is used to represent a sequence of characters. The Char data type is used to represent a single character. String values are defined within a double quote " and Char values are enclosed within a single quote '.

Sr. No. Type Example
1 String − Stores a sequence of characters "TutorialsPoint"
2 Char − Stores fractional values 'T'

Open the elm REPL and try the examples given below −

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>
--------------------------------------
------------------------------------------
> "TutorialsPoint"
"TutorialsPoint" : String
> 'T'
'T' : Char

Bool

The Bool data type in Elm supports only two values − True and False. The keyword Bool is used to represent a Boolean value.

Sr. No. Type Example
1 Bool − Stores values True or False 1==1 returns True

Open the elm REPL and try the examples given below −

C:\Users\dell\elm>elm repl
---- elm-repl 0.18.0 -----------------------------------
------------------------
:help for help, :exit to exit, more at <https://github.com/elm-lang/elm-repl>
----------------------------------------
----------------------------------------
> True
True : Bool
> False
False : Bool
> 1==1
True : Bool
> 1==2
False : Bool
> 1 /= 2 -- not equal
True : Bool
> not True
False : Bool
> not False
True : Bool

Custom Types

Elm supports creating user defined types. For example, consider a payment application. The application needs to store different modes of payment − credit card, debit card and net banking. This can be achieved by defining a custom type and restricting its value to the three acceptable modes of payments.

The following example shows how to make a custom type.

> type PaymentMode = CreditCard|NetBanking|DebitCard
> payment1 = CreditCard
CreditCard : Repl.PaymentMode
> payment2 = DebitCard
DebitCard : Repl.PaymentMode
> payment3 = UPI
-- NAMING ERROR ---------------------------------------------- repl-temp-000.elm

Cannot find variable `UPI`

7| payment3 = UPI

In the above example, we created a PaymentMode custom type. Variables payment1 and payment2 are assigned to PaymentMode values. If the value assigned to the variable does not match any of the values defined by the PaymentMode type, the application will throw a syntax error.

Structured Data types

Structured data types can be used to store multiple values in a structured format. Elm supports the following structured data types −

  • Tuple
  • List
  • Record
  • Record

These will be discussed in detail in the upcoming chapters.

A variable, by definition, is “a named space in the memory” that stores values. In other words, it acts as a container for values in a program. A variable helps programs to store and manipulate values.

Variables in Elm are associated with a specific data type. The data type determines the size and layout of the variable's memory, the range of values that can be stored within that memory and the set of operations that can be performed on the variable.

Variable Naming-Rules

In this section, we will learn about the Variable Naming-Rules.

  • Variable names can be composed of letters, digits, and the underscore character.
  • Variable names cannot begin with a digit. It must begin with either a letter or an underscore.
  • Upper and lowercase letters are distinct because Elm is case-sensitive.

Variable Declaration in Elm

The type syntax for declaring a variable in Elm is given below −

Syntax 1

variable_name:data_type = value

The “ : ” syntax (known as type annotation) is used to associate the variable with a data type.

Syntax 2

variable_name = value-- no type specified

The data type is optional while declaring a variable in Elm. In this case, the data type of the variable is inferred from the value assigned to it.

Illustration

This example uses VSCode editor to write an elm program and execute it using the elm repl.

Step 1 − Create a project folder - VariablesApp. Create a Variables.elm file in the project folder.

Add the following content to the file.

module Variables exposing (..) //Define a module and expose all contents in the module
message:String -- type annotation
message = "Variables can have types in Elm"

The program defines a module Variables. The name of a module must be the same as that of the elm program file. The (..) syntax is used to expose all components in the module.

The program declares a variable message of the type String.

Step 2 − Execute the program.

  • Type the following command in the VSCode terminal to open the elm REPL.
elm repl
  • Execute the following elm statement in the REPL terminal.
> import Variables exposing (..) --imports all components from the Variables module
> message --Reads value in the message varaible and prints it to the REPL 
"Variables can have types in Elm":String
>

Illustration

Use Elm REPL to try the following example.

C:\Users\dell\elm>elm repl
---- elm-repl 0.18.0 ---------------------------------------
--------------------
:help for help, :exit to exit, more at <https://github.com/elm-lang/elm-repl>
-------------------------------------
------------------------------------------
> company = "TutorialsPoint"
"TutorialsPoint" : String
> location = "Hyderabad"
"Hyderabad" : String
> rating = 4.5
4.5 : Float

Here, the variables company and location are String variables and rating is a Float variable.

The elm REPL does not support type annotation for variables. The following example throws an error if the data type is included while declaring a variable.

C:\Users\dell\elm>elm repl
---- elm-repl 0.18.0 -----------------------------------------
------------------
:help for help, :exit to exit, more at <https://github.com/elm-lang/elm-repl>
----------------------------------------
----------------------------------------
> message:String
-- SYNTAX PROBLEM -------------------------------------------- repl-temp-000.elm

A single colon is for type annotations. Maybe you want :: instead? Or maybe you
are defining a type annotation, but there is whitespace before it?

3| message:String
^

Maybe <http://elm-lang.org/docs/syntax> can help you figure it out.

To insert a line break while using the elm REPL, use the \ syntax as shown below −

C:\Users\dell\elm>elm repl
---- elm-repl 0.18.0 --------------------------------------
---------------------
:help for help, :exit to exit, more at <https://github.com/elm-lang/elm-repl>
------------------------------------------
--------------------------------------
> company \ -- firstLine
| = "TutorialsPoint" -- secondLine
"TutorialsPoint" : String

An operator defines some function that will be performed on the data. The values on which the operators work are called operands. Consider the following expression

7 + 5 = 12

Here, the values 7, 5, and 12 are operands, while + and = are operators.

The major operators in Elm can be classified as −

  • Arithmetic
  • Relational
  • Logical

Arithmetic Operators

Assume the values in variables a and b are 7 and 2 respectively.

Show Examples

Sr. No. Operator Description Example
1 +(Addition) returns the sum of the operands a+b is 9
2 -(Subtraction) returns the difference of the values a-b is 5
3 * (Multiplication) returns the product of the values a*b is 14
4 / (Float Division) performs division operation and returns a float quotient a / b is 3.5
5 //(Integer Division) performs division operation and returns a integer quotient a // b is 3
6 % (Modulus) performs division operation and returns the remainder a % b is 1

Relational Operators

Relational Operators test or define the kind of relationship between two entities. These operators are used to compare two or more values. Relational operators return a Boolean value, i.e. true or false.

Assume the value of a is 10 and b is 20.

Show Examples

Sr. No. Operator Description Example
1 > Greater than (a > b) is False
2 < Lesser than (a < b) is True
3 >= Greater than or equal to (a >= b) is False
4 <= Lesser than or equal to (a <= b) is True
5 == Equality (a == b) is false
6 != Not equal (a != b) is True

Comparable Types

Comparison operators like >= or < work with comparable types. These are defined as numbers, characters, strings, and lists, tuples. The comparable types on both sides of the operator must be the same.

Sr. No. Comparable Type Example
1 number 7>2 gives True
2 character 'a' =='b' gives False
3 string "hello" =="hello" gives True
4 tuple (1,"One")==(1,"One") gives True
5 list [1,2]==[1,2] gives True

Open the elm REPL and try the examples shown below −

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>
--------------------------------------------------------------------------------
> 7>2
True : Bool
> 7.0>2
True : Bool
> 7.0<2.0
False : Bool
> 'a' > 'b'
False : Bool
> 'a' < 'b'
True : Bool
> "a" < "b"
True : Bool
> (1,2) > (2,3)
False : Bool
> ['1','3'] < ['2','1']
True : Bool
>

Logical Operators

Logical Operators are used to combine two or more conditions. Logical operators too return a Boolean value.

Show Examples

Sr. No. Operator Description Example
1 && The operator returns true only if all the expressions specified return true (10>5) && (20>5) returns True
2 || The operator returns true if at least one of the expressions specified return true (10 < 5) || (20 >5) returns True
3 not The operator returns the inverse of the expression’s result. For E.g.: !(>5) returns false. not (10 < 5) returns True
4 xor The operator returns true only if exactly one input returns true. The operator returns false if both the expressions return true. xor (10 > 5 ) (20 > 5) returns false

Decision-making structures requires that the programmer specifies one or more conditions to be evaluated or tested by the program, along with a statement or statements to be executed if the condition is determined to be true, and optionally, other statements to be executed if the condition is determined to be false.

Shown below is the general form of a typical decision-making structure found in most of the programming languages

A decision-making construct evaluates a condition before the instructions are executed. Decision-making constructs in Elm are classified as follows −

Sr. No. Statement Description
1 if...then...else statement The if statement consists of a Boolean expression followed by then which is executed if the expression returns true and else which is executed if the expression returns false
2 nested if statement You can use one if...then...else inside another if.
3 case statement Tests the value of a variable against a list of values.

if...then...else Statement

The if…then construct evaluates a condition before a block of code is executed. If the Boolean expression evaluates to true, then the block of code inside the then statement will be executed. If the Boolean expression evaluates to false, then the block of code inside the else statement will be executed.

Unlike other programming languages, in Elm we must provide the else branch. Otherwise, Elm will throw an error.

Syntax

if boolean_expression then statement1_ifTrue else statement2_ifFalse

Illustration

Try the following example in the REPL terminal.

> if 10>5 then "10 is bigger" else "10 is small"
"10 is bigger" : String

Nested If

The nested if statement is useful for testing multiple conditions. The syntax of a nested if statement is given below −

if boolean_expression1 then statement1_ifTrue else if boolean_expression2 then statement2_ifTrue else statement3_ifFalse

Illustration

Try the following example in the Elm REPL −

> score=80
80 : number
> if score>=80 then "Outstanding" else if score > = 70 then "good" else "average"
"Outstanding" : String

Case statement

The case statement can be used to simplify the if then else statement. The syntax of a case statement is as given below −

case variable_name of
   constant1 -> Return_some_value
   constant2 -> Return_some_value
   _ -> Return_some_value if none of the above values match

The case statement checks if the value of a variable matches a predefined set of constants and returns the corresponding value. Note that value returned by each case must be of the same type. If the variables value does not match any of the given constants, the control is passed to * default * (denoted by //_ ) and the corresponding value is returned.

Illustration

Try the following example in the Elm REPL −

> n = 10
10 : number
> case n of \
| 0 -> "n is Zero" \
| _ -> "n is not Zero"
"n is not Zero" : String

The above code snippet checks if the value of n is zero. The control is passed to default, which returns the string “n is not Zero”.

Elm is a functional programming language. Elm uses the concept of recursion as an alternative to traditional looping constructs.

This chapter discusses the concept of recursion.

Recursion

Some computer programming languages allow a module or function to call itself. This technique is known as recursion.

Illustration

In this program, we will see how to use recursion to display hello five times.

Step 1 − Create a file Loop.elm

Create a module Loop and define a function sayHello. The function sayHello takes an integer value as input and returns a string value.

module Loop exposing(..)
//function signature
sayHello:Int ->String
//function implementation
sayHello n =
   case n of
   1 -> "Hello:1 "
   _ -> "Hello:" ++ toString (n) ++ " " ++ sayHello(n-1)

The function sayHello checks if parameter passed is 1. If the parameter is 1, then function will return, otherwise it will create a string Hello and call the same function.

Step 2 − Invoke sayHello from REPL

Open the elm REPL from current project folder (location of Loop.elm file).

//import the module Loop
> import Loop exposing(..)
//invoke the sayHello function with parameter value as 5
> sayHello 5
"Hello:5 Hello:4 Hello:3 Hello:2 Hello:1 Hello:0 " : String
>

Illustration

The following example prints the sum of n numbers using recursion.

> sumOfNos n =\
| if n==0 then 0 \
| else (n) + sumOfNos (n-1)
<function> : number -> number1

In the elm REPL, we created a function sumOfNos that takes an input number and sums all numbers from 0 to that number.

For example, if we pass input as 5, it will sum up 1+2+3+4+5 which is 15.

> ssumOfNos 5
15 : number

The output of the program is shown above.

Functions are the building blocks of an Elm program. A function is a set of statements to perform a specific task.

Functions organize the program into logical blocks of code. Once defined, functions may be called to access code. This makes the code reusable. Moreover, functions make it easy to read and maintain the program’s code.

Steps to using a function

There are three steps to using a function −

Function Declaration

A function declaration tells the compiler about a function's name, return type, and parameters. The syntax for declaring a function is given below −

fn_name:data_type_of_the_parameters ->return_type

The function declaration specifies the following −

  • Name of the function.

  • Data type of the parameters. This is optional as a function may or may not have parameters.

  • Data type of the value, which the function will return. Functions in Elm must always return a value as Elm is a functional programming language. Unlike functions in other programing languages, Elm functions do not use the return keyword to return a value.

Function Definition or Function Implementation

A function definition provides the actual body of the function. A function definition specifies how a specific task would be done. The syntax for defining a function is as given below −

fn_name parameter1 parameter2 = statements

Invoking or Calling a Function

A function must be called so as to execute it. The syntax for calling a function is given below −

fn_name parameter1 parameter2

Illustration

The following code defines a function greet. The function returns a string "Hello".

> greet = \
| if True then \
| "Hello" \
| else \
| "GoodBye"
"Hello" : String
> greet
"Hello" : String

Parameterized Functions

Parameters are a mechanism to pass values to a function. The values of the parameters are passed to the function at the time of function invocation.

Illustration 1

The following example defines a function fn_add. The function accepts two numbers as parameters and returns their sum. Try the following in elm REPL −

> fn_add x y = x+y
<function> : number -> number -> number
> fn_add 10 20
30 : number

Illustration 2

The following example defines a function sayHello. The sayHello function accepts and returns a String value as parameter and returns a String.

> sayHello name = "Hello "++ name
<function> : String -> String
> sayHello "Tutorialspoint"
"Hello Tutorialspoint" : String
>

Pipe Operator

To understand pipe operator |>, let us consider an example where we have a list of different strings ["a","b","c"] . Now we need a single string, which is separated by −

The following example shows how to do that with String.join

> String.join "-" ["a","b","c","d","e","f"]
"a-b-c-d-e-f" : String

The same action can be performed by using a pipe operator |>. The pipe operator can be used to chain multiple function calls.

> ["a","b","c","d","e","f"] |> String.join "-"
"a-b-c-d-e-f" : String
> ["a","b","c","d","e","f"] |> List.reverse |> String.join "-"
"f-e-d-c-b-a" : String

In the first example, we are chaining the list to join method. In the second case, the same list is piped to reverse function and thereafter piped to join. So, the list is displayed in reversed and joined.

A sequence of Unicode characters is called a String. In Elm, strings are enclosed in "" double quotes. A String is a chunk of text as shown below.

> "TutorialsPoint"
"TutorialsPoint" : String
> location = "Hyderabad" --variable
"Hyderabad" : String
> location
"Hyderabad" : String
>

String Functions

Some common functions that can be used to query or manipulate string values are given below. Use REPL to try the examples given below.

Sr. No Method Description
1 isEmpty : String -> Bool checks string is empty
2 reverse : String -> String reverses a input string
3 length : String -> Int returns an integer length
4 append :String -> String -> String appends two string and returns a new string
5 append :String -> Sconcat : List String -> String appends a list of strings and returns a new string
6 split : String -> String -> List String splits an input string using a given separator, returns a string list
7 slice : Int -> Int -> String -> String returns a substring given a start , end index and input string
8 contains : String -> String -> Bool returns true if second string contains the first one
9 toInt : String -> Result.Result String Int parses a String to Integer
10 toInt : String -> Result.Result String Int parses a String to Integer
11 toFloat : String -> Result.Result String Float parses a String to float
12 fromChar : Char -> String creates a string from a given character.
13 toList : String -> List Char converts string to list of characters
14 fromList : List Char -> String converts a list of characters into a String
15 toUpper : String -> String converts input string to upper case
16 trim : String -> String gets rid of whitespace on both sides of a string.
17 filter : (Char -> Bool) -> String -> String filters set of characters from input string
18 map : (Char -> Char) -> String -> String transforms every character in an input string

isEmpty

This function can be used to determine if a string is empty. This function returns True if the supplied String is empty.

Syntax

String.isEmpty String_value

To check the signature of function, type the following in elm REPL −

> String.isEmpty
<function> : String -> Bool

Signature of the function shows Bool as return type and input type as String −

Illustration

> String.isEmpty ""
True : Bool
> String.isEmpty "Tutorialspoint"
False : Bool
> location = "Hyderabad"
"Hyderabad" : String
> String.isEmpty location
False : Bool

reverse

This function reverses a string.

Syntax

String.reverse String_value

To check the signature of function, type the following in elm REPL −

> String.reverse
<function> : String -> String

Signature of the function shows String as return type and input type as String −

Illustration

> String.reverse "TutorialsPoint"
"tnioPslairotuT" : String

length

This function returns the length of a string.

Syntax

String.length String_value

To check the signature of function, type the following in elm REPL −

> String.length
<function-> : String -> Int

Signature of the function shows Int as return type and input type as String.

Illustration

> String.length "Mohtashim"
9 : Int

append

This function returns a new string by appending two strings.

Syntax

String.append String_value1 String_value2

To check the signature of function, type the following in elm REPL −

> String.append
<function-> : String -> String -> String

Signature of shows two String input parameters and one String output parameter

Illustration

> String.append "Tutorials" "Point"
TutorialsPoint : String

concat

This function returns a new string by concatenating many strings into one.

Syntax

String.concat [String1,String2,String3]

To check the signature of function, type the following in elm REPL −

> String.concat
<function> : List String -> String

Signature of shows a List of String input parameter and String return type

Illustration

> String.concat ["Hello","Tutorials","Point"]
HelloTutorialsPoint : String

split

This function splits a string using a given separator.

Syntax

String.split string_seperator String_value

To check the signature of function, type the following in elm REPL −

> String.split
<function> : String -> String -> List String

Signature of shows two input String parameters and output as a list of string type.

Illustration

> String.split "," "Hello,Tutorials,Point"
["Hello","Tutorials","Point"] : List String

slice

This function returns a substring given a start and end index. Negative indexes are taken starting from the end of the list. The value of the index starts from zero.

Syntax

String.slice start_index end_index String_value

To check the signature of function, type the following in elm REPL −

> String.slice
<function> : Int -> Int -> String -> String

Signature of shows three input parameter and one return type.

Illustration

> String.slice 0 13 "TutorialsPoint"
"TutorialsPoin" : String

contains

This function returns a True if the second string contains the first one.

Syntax

String.contains string1 string2

To check the signature of function, type the following in elm REPL −

> String.contains
<function> : String -> String -> Bool

Signature of shows bool return type and two input parameters

Illustration

> String.contains "Point" "TutorialsPoint"
True : Bool

toInt

This function converts a string into an int.

Syntax

String.toInt string_value

To check the signature of function, type the following in elm REPL −

> String.toInt
<function> : String -> Result.Result String Int

Since toInt can return error, the return type is Result, which is String or Int.

Illustration

> String.toInt "20"
Ok 20 : Result.Result String Int
> String.toInt "abc"
Err "could not convert string 'abc' to an Int" : Result.Result String Int

toFloat

This function converts a string into a float.

Syntax

String.toFloat string_value

To check the signature of function, type the following in elm REPL −

> String.toFloat
<function> : String -> Result.Result String Float

Since toFloat can return error, the return type is Result, which is String or Float.

Illustration

> String.toFloat "20.50"
Ok 20.5 : Result.Result String Float
> String.toFloat "abc"
Err "could not convert string 'abc' to a Float" : Result.Result String Float

fromChar

This function creates a string from a given character.

Syntax

String.fromChar character_value

To check the signature of function type following in elm REPL −

> String.fromChar
<function> : Char -> String

The signature shows String as return type and input as Char type

Illustration

> String.fromChar 'c'
"c" : String

toList

This function converts a string to a list of characters.

Syntax

String.toList string_value

To check the signature of function, type the following in elm REPL −

> String.toList
<function> : String -> List Char

The signatures shows function returns a list of characters and takes input a string.

Illustration

> String.toList "tutorialspoint"
['t','u','t','o','r','i','a','l','s','p','o','i','n','t'] : List Char

fromList

This function converts a list of characters into a String.

Syntax

String.fromList list_of_characters

To check the signature of function, type the following in elm REPL −

> String.fromList
<function> : List Char -> String

The signatures shows function returns a list of characters and takes input a string.

Illustration

> String.fromList ['h','e','l','l','o']
"hello" : String

toUpper

This function converts a string to all upper case.

Syntax

String.toUpper String_value

To check the signature of function, type the following in elm REPL −

> String.toUpper
<function> : String -> String

Illustration

> String.toUpper "hello"
"HELLO" : String

toLower

This function converts a string to all lower case.

Syntax

String.toLower String_value

To check the signature of function, type the following in elm REPL −

> String.toLower
<function> : String -> String

Illustration

> String.toLower "AbCd"
"abcd" : String

trim

This function gets rid of whitespace on both sides of a string.

Syntax

String.trim String_value

To check the signature of function, type the following in elm REPL −

> String.trim
<function> : String -> String

Illustration

> String.trim "tutorialspoint "
"tutorialspoint" : String

filter

This function filters a set of characters from input String. Keep only the characters that pass the test.

Syntax

String.filter test_function string_value

To check the signature of function, type the following in elm REPL −

> String.filter
<function> : (Char -> Bool) -> String -> String

The signature shows filter takes two input parameters and returns a String. The first parameter is a function, which has input Char and returns Bool.

Illustration

In the example, we are passing Char.isUpper as parameter to filter method; it returns all upper-case characters as shown below.

> import Char
> String.filter Char.isUpper "abcDEF"
"DEF" : String

map

This function takes a String and transforms every character in a string.

Syntax

String.filter mapping_function string_value

To check the signature of function, type the following in elm REPL −

> String.map
<function> : (Char -> Char) -> String -> String

Illustration

The following example replaces the character o with @ −

> String.map (\c -> if c == 'o' then '@' else c) "TutorialsPoint"
"Tut@rialsP@int" : String

The List, Tuples and Record data structures can be used to store a collection of values.

This chapter discusses how to use List in Elm.

A List is a collection of homogeneous values. The values in a list must all be of the same data type.

Consider the following limitations while using variables to store values −

  • Variables are scalar in nature. In other words, at the time of declaration a variable can hold only one value. This means that to store n values in a program, n variable declarations will be needed. Hence, the use of variables is not feasible when one needs to store a larger collection of values.

  • Variables in a program are allocated memory in random order, thereby making it difficult to retrieve/read the values in the order of their declaration.

Syntax

List_name = [value1,value2,value3.....valuen]

Illustration

The following example shows how to use a List in Elm. Try this example in elm REPL −

> myList1 = [10,20,30]
[10,20,30] : List number
> myList2 = ["hello","world"]
["hello","world"] : List String

If we try adding values of different types into a list, the compiler will throw a type mismatch error. This is shown below.

> myList = [1,"hello"]
-- TYPE MISMATCH 
--------------------------------------------- 
repl-temp-000.elm

The 1st and 2nd entries in this list are different types of values.

4| [1,"hello"]
^^^^^^^
The 1st entry has this type:
   number
But the 2nd is:
   String

List operations

Following table shows the common operations on a List −

Sr. No Method Description
1 isEmpty : List a -> Bool checks if list is empty
2 reverse : List a -> Bool reverses input list
3 length : List a -> Int returns size of the list
4 maximum : List comparable -> Maybe.Maybe comparable returns maximum value
5 minimum : List comparable -> Maybe.Maybe comparable returns minimum value
6 sum : List number -> number returns sum of all elements in list
7 product : List number -> number checks if list is empty
8 sort : List comparable -> List comparable sorts list in ascending order
9 concat : List (List a) -> List a merges a bunch of list into one
10 append : List a -> List a -> List a merges two lists together
11 range : Int -> Int -> List Int returns a list of numbers from start to end
12 filter : (a -> Bool) -> List a -> List a filters list of values from input list
13 head : List a -> Maybe.Maybe a returns the first element from list
14 tail : : List a -> Maybe.Maybe (List a) returns all elements except the head

isEmpty

This function returns true if a list is empty.

Syntax

List.isEmpty list_name

To check the signature of function, type the following in elm REPL −

> List.isEmpty
<function> : List a -> Bool

Illustration

> List.isEmpty
<function> : List a -> Bool

> List.isEmpty [10,20,30]
False : Bool

reverse

This function reverses the list.

Syntax

List.reverse list_name

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.reverse
<function> : List a -> List a

Illustration

> List.reverse [10,20,30]
[30,20,10] : List number

longueur

Cette fonction renvoie la longueur d'une liste.

Syntaxe

List.length list_name

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.length
<function> : List a -> Int

Illustration

> List.length [10,20,30]
3 : Int

maximum

Cette fonction renvoie l'élément maximum dans une liste non vide.

Syntaxe

List.maximum list_name

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.maximum
<function> : List comparable -> Maybe.Maybe comparable

Illustration

> List.maximum [10,20,30]
Just 30 : Maybe.Maybe number
> List.maximum []
Nothing : Maybe.Maybe comparable

le minimum

Cette fonction renvoie l'élément minimum dans une liste non vide.

Syntaxe

List.minimum list_name

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.minimum
<function> : List comparable -> Maybe.Maybe comparable

Illustration

> List.minimum [10,20,30]
Just 10 : Maybe.Maybe number

somme

Cette fonction renvoie la somme de tous les éléments d'une liste.

Syntaxe

List.sum list_name

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.sum
<function> : List number -> number

Illustration

> List.sum [10,20,30]
60 : number

produit

Cette fonction renvoie le produit de tous les éléments d'une liste.

Syntaxe

List.product list_name

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

<function>  : List number ->  number

Illustration

List.product [10,20,30]
6000 : number

Trier

Cette fonction trie les valeurs de la plus basse à la plus élevée dans une liste.

Syntaxe

List.sort list_name

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.sort
<function> : List comparable -> List comparable

Illustration

> List.sort [10,20,30]
[10,20,30] : List number

concat

Cette fonction concatène un tas de listes en une seule liste.

Syntaxe

List.concat [ [list_name1],[list_name2],[list_name3],.....[list_nameN] ]

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.concat
<function> : List (List a) -> List a

Illustration

> List.concat [[10,20], [30,40],[50,60]]
[10,20,30,40,50,60] : List number

ajouter

Cette fonction rassemble deux listes.

Syntaxe

List.append [list_name1] [list_name2]

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.append
<function> : List a -> List a -> List a

Illustration

> List.append [10,20] [30,40]
[10,20,30,40] : List number

L'opérateur ++ peut également être utilisé pour ajouter une liste à une autre. Ceci est illustré dans l'exemple ci-dessous -

> [10.1,20.2] ++ [30.3,40.4]
[10.1,20.2,30.3,40.4] : List Float

intervalle

Cette fonction crée une liste de nombres, chaque élément augmentant de un. Le nombre le plus bas et le plus élevé devant figurer dans la liste est transmis à la fonction.

Syntaxe

List.range start_range end_range

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.range
<function> : Int -> Int -> List Int

Illustration

> List.range 1 10
[1,2,3,4,5,6,7,8,9,10] : List Int

filtre

Cette fonction filtre un ensemble de valeurs de la liste d'entrée. Conservez uniquement les valeurs qui réussissent le test.

Syntaxe

List.filter test_function input_list

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.filter
<function> : (a -> Bool) -> List a -> List a

Illustration

L'exemple suivant filtre tous les nombres pairs d'une liste d'entrée

> List.filter (\n -> n%2==0) [10,20,30,55]
[10,20,30] : List Int

tête

Cette fonction renvoie le premier élément de la liste d'entrée.

Syntaxe

List.head input_list

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.head
<function> : List a -> Maybe.Maybe a

Illustration

> List.head [10,20,30,40]
Just 10 : Maybe.Maybe number
> List.head []
Nothing : Maybe.Maybe a

queue

Cette fonction renvoie tous les éléments après le premier dans la liste.

Syntaxe

List.tail input_list

Pour vérifier la signature de la fonction, tapez ce qui suit dans elm REPL -

> List.tail
<function> : List a -> Maybe.Maybe (List a)

Illustration

> List.tail [10,20,30,40,50]
Just [20,30,40,50] : Maybe.Maybe (List number)
> List.tail [10]
Just [] : Maybe.Maybe (List number)
> List.tail []
Nothing : Maybe.Maybe (List a)

Utilisation de l'opérateur Cons

L'opérateur cons (::) ajoute un élément au début d'une liste.

Illustration

> 10::[20,30,40,50]
[10,20,30,40,50] : List number

Le nouvel élément à ajouter et le type de données des valeurs de la liste doivent correspondre. Le compilateur renvoie une erreur si les types de données ne correspondent pas.

> [1,2,3,4]::[5,6,7,8]
-- TYPE MISMATCH ---------------------------------
------------ repl-temp-000.elm

The right side of (::) is causing a type mismatch.

3| [1,2,3,4]::[5,6,7,8]
			  ^^^^^^^^^
(::) is expecting the right side to be a:

   List (List number)

But the right side is:

   List number
Hint: With operators like (::) I always check the left side first. If it seems fine, 
I assume it is correct and check the right side. So the 
problem may be in how the left and right arguments interact.

Les listes sont immuables

Vérifions si les listes sont immuables dans Elm. La première liste myList lorsqu'elle est concaténée avec la valeur 1 crée une nouvelle liste et est renvoyée à myListCopy . Par conséquent, si nous affichons la liste initiale, ses valeurs ne seront pas modifiées.

> myList = [10,20,30]
[10,20,30] : List number
> myListCopy = 1::myList
[1,10,20,30] : List number
> myList
[10,20,30] : List number
>myList == myListCopy
False : Bool

Parfois, il peut être nécessaire de stocker une collection de valeurs de types variés. Elm nous donne une structure de données appelée tuple qui sert cet objectif.

Un tuple représente une collection hétérogène de valeurs. En d'autres termes, les tuples permettent de stocker plusieurs champs de types différents. Un tuple stocke un nombre fixe de valeurs. Les tuples sont utiles lorsque vous souhaitez renvoyer plusieurs valeurs de types différents à partir d'une fonction. Ces structures de données sont immuables comme les autres types dans elm.

Syntaxe

(data1,data2)

Un exemple simple est présenté ci-dessous -

> ("TuotrialsPoint",5,True,"Hyderabad")
("TuotrialsPoint",5,True,"Hyderabad") : ( String, number, Bool, String )

Dans nos sections suivantes, nous découvrirons les différentes opérations de tuple.

première

Cette opération extrait la première valeur d'un tuple.

Syntaxe

Tuple.first tuple_name
> Tuple.first
<function> : ( a1, a2 ) -> a1

Illustration

> Tuple.first (10,"hello")
10 : number

seconde

le second L'opération tuple extrait la deuxième valeur d'un tuple.

Syntaxe

Tuple.second tuple_name
> Tuple.second
<function> : ( a1, a2 ) -> a2

Illustration

> Tuple.second (10,"hello")
"hello" : String

Liste des tuples

Une liste peut stocker des tuples. Si des tuples sont utilisés dans une liste, assurez-vous qu'ils sont tous du même type de données et qu'ils ont le même nombre de paramètres.

Illustration

> [("hello",20),("world",30)]
[("hello",20),("world",30)] : List ( String, number )

Tuple avec fonction

Une fonction peut renvoyer des tuples. De plus, les tuples peuvent être passés en tant que paramètres aux fonctions.

Illustration 1

L'exemple suivant définit une fonction fn_checkEven. Cette fonction accepte une valeur entière comme paramètre et renvoie un tuple.

> fn_checkEven no = \
   if no%2 == 0 then \
      (True,"The no is Even")\
   else \
      (False,"No is not even")
<function> : Int -> ( Bool, String )
> fn_checkEven 10
(True,"The no is Even") : ( Bool, String )
> fn_checkEven 11
(False,"No is not even") : ( Bool, String )
>

Illustration 2

Ce qui suit passe un tuple en tant que paramètre à une fonction.

> fn_add (a,b) = \
| a+b
<function> : ( number, number ) -> number
> fn_add (10,20)
30 : number

La fonction fn_add prend un tuple avec 2 valeurs numériques et renvoie leur somme.

Destructuration

La destruction consiste à diviser un tuple en valeurs individuelles. Pour accéder à des valeurs individuelles dans un tuple avec trois éléments ou plus, nous utilisons la déstructuration. Ici, nous affectons chaque valeur d'un tuple à différentes variables. L'utilisation de _ permet de définir des espaces réservés pour les valeurs qui seront ignorées ou ignorées.

Illustration

> (first,_,_) = (10,20,30)
10 : number
> first
10 : number

Illustration

Dans cet exemple, nous utiliserons la syntaxe de bloc let..in pour déstructurer. Le bloc let contient les variables et le bloc in contient les expressions qui doivent être évaluées et la valeur qui doit être renvoyée.

> t1 = (10,20,30)
(10,20,30) : ( number, number1, number2 )
> let \
(a,b,c) = t1 \
in\
a + b +c
60 : number

Nous déclarons les variables abc dans la clause let et y accédons en utilisant la clause in.

La structure de données d'enregistrement dans Elm peut être utilisée pour représenter les données sous forme de paires clé-valeur. Un enregistrement peut être utilisé pour organiser les données associées afin de faciliter l'accès et la mise à jour des données. Les enregistrements Elm sont similaires aux objets en JavaScript. Les éléments de données d'un enregistrement sont appelés champs.

Définition d'un enregistrement

Utilisez la syntaxe suivante pour définir un enregistrement -

Syntaxe

record_name = {fieldname1 = value1, fieldname2 = value2....fieldnameN = valueN}

Un enregistrement peut stocker des données de plusieurs types. Les noms de champ dans un enregistrement doivent être conformes aux règles générales de dénomination d'un identifiant Elm.

Accéder aux valeurs d'enregistrement

Utilisez la syntaxe suivante pour accéder aux champs individuels d'un enregistrement.

Syntaxe

record_name.fieldname

OU

.fieldname record_name

Illustration

Essayez ce qui suit dans la REPL Elm -

> company = {name="TutorialsPoint",rating=4.5}
{ name = "TutorialsPoint", rating = 4.5 } : { name : String, rating : Float }
> company.name
"TutorialsPoint" : String
> .rating company
4.5 : Float

Utilisation de l'enregistrement avec la liste

Un enregistrement peut être stocké dans une liste. Toutes les valeurs de champ de l'enregistrement doivent être du même type.

Syntaxe

list_name = [ {field_name1 = value1},{field_name1 = value2}]

OU

list_name = [record_name1, record_name2, record_name3....record_nameN]

Illustration

Essayez ce qui suit dans Elm REPL -

> [{name = "Mohtashim"},{name = "kannan"}]
[{ name = "Mohtashim" },{ name = "kannan" }] : List { name : String }
> record1 = {name = "FirstRecord"}
{ name = "FirstRecord" } : { name : String }
> record2 = {name = "SecondRecord"}
{ name = "SecondRecord" } : { name : String }
> recordList = [record1,record2]
[{ name = "FirstRecord" },{ name = "SecondRecord" }] : List { name : String }

Mettre à jour un enregistrement

Les enregistrements sont immuables dans Elm. Lorsqu'un enregistrement est mis à jour, un nouvel enregistrement avec des valeurs mises à jour est renvoyé. Le champ peut contenir une valeur d'un type différent lors de la mise à jour d'un enregistrement.

Syntaxe

{record_name | field_name1 = new_value1, field_name2 = new_value2,field_name3 = new_value3....field_nameN = new_valueN}

Illustration

Essayez ce qui suit dans Elm REPL -

> record1 = {name="FirstRecord"}
{ name = "FirstRecord" } : { name : String }
> record1_updated = {record1 | name = "FirstRecordUpdate"}
{ name = "FirstRecordUpdate" } : { name : String }
> record1
{ name = "FirstRecord" } : { name : String }
> record1 == record1_updated
False : Bool

Illustration

L'exemple suivant met à jour plusieurs champs d'un enregistrement. Essayez ce qui suit dans Elm REPL -

> record3 = {a = 1,b = 2,c = 3,d = 4,e = 5}
{ a = 1, b = 2, c = 3, d = 4, e = 5 }
: { a : number, b : number1, c : number2, d : number3, e : number4 }
> record4 = {record3 | d=400 ,e=500}
{ a = 1, b = 2, c = 3, d = 400, e = 500 }
: { a : number2, b : number3, c : number4, d : number, e : number1 }
>

Alias ​​de types

L'alias de type définit un schéma pour un enregistrement. En d'autres termes, un alias de type définit quels champs peuvent stocker les enregistrements et le type de valeur que ces champs peuvent stocker. Par conséquent, le programmeur ne fera pas d'erreur en manquant un attribut spécifique lors de l'attribution de valeurs.

Syntaxe

type alias alias_name = {field_name1:data_type,field_name2:data_type,....field_nameN:data_type}

Illustration

Exécutez ce qui suit dans Elm REPL -

> type alias Developer = { name:String,location:String,age:Int}
> dev1 = Developer "kannan" "Mumbai" 20
{ name = "kannan", location = "Mumbai", age = 20 } : Repl.Developer
> dev2 = Developer "mohtashim" "hyderabad" 20
{ name = "mohtashim", location = "hyderabad", age = 20 } : Repl.Developer
>

Maintenant, si vous oubliez de taper l'emplacement et l'âge, l'instruction renvoie une fonction, qui a des paramètres d'entrée pour les champs d'emplacement et d'âge.

> dev3 = Developer "Bhagavati"
<function> : String -> Int -> Repl.Developer
We can invoke the function as shown below and pass to it the values for location and age fields.
> dev3 "Pune" 25
{ name = "Bhagavati", location = "Pune", age = 25 } : Repl.Developer

Une erreur est une condition inattendue dans un programme. Des erreurs peuvent se produire au moment de la compilation ou de l'exécution. Des erreurs de compilation se produisent lors de la compilation d'un programme (par exemple, une erreur dans la syntaxe du programme) tandis que des erreurs d'exécution se produisent pendant l'exécution du programme. Contrairement à d'autres langages de programmation, Elm ne génère pas d'erreurs d'exécution.

Considérez une application qui accepte l'âge d'un utilisateur. L'application doit générer une erreur si l'âge est nul ou négatif. Dans ce cas, l'application Elm peut utiliser le concept de gestion des erreurs pour déclencher explicitement une erreur au moment de l'exécution si l'utilisateur entre zéro ou une valeur négative comme âge. La gestion des erreurs spécifie la marche à suivre si quelque chose d'inattendu se produit pendant l'exécution du programme.

Le langage de programmation Elm gère les erreurs de la manière suivante -

  • MayBe
  • Result

Peut être

Considérez la fonction de recherche dans une application. La fonction de recherche renvoie des données associées si le mot-clé de recherche est trouvé, sinon rien ne renvoie. Ce cas d'utilisation peut être implémenté dans Elm en utilisant le type MayBe.

Syntaxe

variable_name:MayBe data_type

Une variable de type MayBe peut contenir l'une des valeurs suivantes -

  • Just some_Value - Ceci est utilisé s'il existe des données valides.

  • Rien - Ceci est utilisé si la valeur est absente ou inconnue. Rien n'est équivalent à null dans d'autres langages de programmation.

Illustration

L'exemple suivant montre comment utiliser le type MayBe avec des variables et une fonction.

Step 1 - Créer un MayBeDemo.elm fichier et ajoutez-y le code suivant

-- MayBeDemo.elm
module MayBeDemo exposing(..)
import Maybe

--declaring a MayBe variable and assigning value to it
userName : Maybe String
userName = Just "Mohtashim"

--declaring a MayBe variable and assigning value to it
userAge :Maybe Int
userAge = Just 20

--declaring a MayBe variable and assigning value to it
userSalary:Maybe Float
userSalary = Nothing

--declaring a custom type
type Country = India | China | SriLanka

--defining a function that takes a String parameter as input and returns a value of type MayBe

getCountryFromString : String -> Maybe Country
getCountryFromString p =
case p of
   "India"
      -> Just India
   "China"
      -> Just China
   "SriLanka"
      -> Just SriLanka
   _
      -> Nothing

Step 2 - Importez le module dans elm repl et exécutez-le comme indiqué ci-dessous

E:\ElmWorks\ErroApp> elm repl
---- elm-repl 0.18.0 -----------------------------------------------------------
:help for help, :exit to exit, more at 
      
        -------------------------------------------------------------------------------- > import MayBeDemo exposing(..) > userName Just "Mohtashim" : Maybe.Maybe String > userAge Just 20 : Maybe.Maybe Int > userSalary Nothing : Maybe.Maybe Float > getCountryFromString "India" Just India : Maybe.Maybe MayBeDemo.Country > getCountryFromString "india" Nothing : Maybe.Maybe MayBeDemo.Country 
      

La fonction vérifie si la valeur transmise à la fonction est l'Inde, la Chine ou le SriLanka. Si la valeur du paramètre ne correspond à aucune de ces valeurs, elle ne renvoie rien.

Résultat

Prenons un exemple, où l'application doit valider une condition et générer une erreur si la condition n'est pas satisfaite. Le type de résultat peut être utilisé pour y parvenir. Le type de résultat doit être utilisé si l'application souhaite explicitement déclencher une erreur et renvoyer des détails sur ce qui n'a pas fonctionné.

Syntaxe

La déclaration de type de résultat prend deux paramètres: le type de données de l'erreur (généralement String) et le type de données du résultat à renvoyer si tout se passe bien.

type Result error_type data_value_type
= Ok data_value
| Err error_message

Le type de résultat renvoie l'une des valeurs suivantes -

  • Ok some_value - Représente le résultat à retourner

  • Err - Représente le message d'erreur à renvoyer si les conditions attendues ne sont pas satisfaites.

Illustration 1

Essayez l'exemple suivant dans la REPL Elm -

> String.toInt
<function> : String -> Result.Result String Int
-- successful result
> String.toInt "10"
Ok 10 : Result.Result String Int
-- unsuccessful result , Error
> String.toInt "a"
Err "could not convert string 'a' to an Int" : Result.Result String Int

La fonction String.toInt renvoie la valeur Integer si le paramètre passé est valide. Si le paramètre n'est pas un nombre, la fonction renvoie une erreur.

Illustration 2

L'exemple suivant accepte l'âge comme paramètre. La fonction renvoie l'âge s'il est compris entre 0 et 135, sinon elle renvoie un message d'erreur approprié.

Step 1 - Créez un fichier ResultDemo.elm et ajoutez-y le code suivant.

--ResultDemo.elm
module ResultDemo exposing(..)

userId : Result String Int
userId = Ok 10

emailId : Result String Int
emailId = Err "Not valid emailId"

isReasonableAge : String -> Result String Int
isReasonableAge input =
   case String.toInt input of
      Err r ->
         Err "That is not a age!"

   Ok age ->
      if age < 0 then
         Err "Please try again ,age can't be negative"
      else if age > 135 then
         Err "Please try agian,age can't be this big.."

   else
      Ok age

Step 2 - Importez le module dans le package elm et exécutez-le comme indiqué ci-dessous

E:\ElmWorks\ElmRepo\15_ErrorHandling\15_Code> elm repl
---- elm-repl 0.18.0 -----------------------------------------------------------
:help for help, :exit to exit, more at <https://github.com/elm-lang/elm-repl>
--------------------------------------------------------------------------------
> import ResultDemo exposing (..)
> userId
Ok 10 : Result.Result String Int
> emailId
Err "Not valid emailId" : Result.Result String Int
> isReasonableAge "10"
Ok 10 : Result.Result String Int
> isReasonableAge "abc"
Err "That is not a age!" : Result.Result String Int

Dans ce chapitre, nous discuterons de la manière standard de créer des applications dans la plateforme Elm. Elm utilise un modèle architectural similaire au modèle Model-View-Controller.

Voici les quatre parties principales de l'architecture Elm.

  • Model
  • View
  • Message
  • Update

Comment fonctionne l'architecture Elm

le modelcontient l'état de l'application. Par exemple, si une application affiche une liste de clients, l'état contiendra chaque donnée client. Pour afficher l'état de manière présentable, unview/ html doit être généré. Une fois que l'utilisateur interagit avec la vue en appuyant sur un bouton ou en saisissant des données dans un formulaire, la vue génère des signaux appelésmessages. Les messages sont transmis auupdateméthode, qui évalue les messages et prend les mesures appropriées. Par conséquent, la méthode de mise à jour générera un nouveau modèle.

Le nouveau modèle génère une nouvelle vue. La vue conduira à de nouvelles interactions de l'utilisateur aux messages de signalisation, qui vont à la fonction de mise à jour. De plus, la fonction crée un nouveau modèle. Ainsi, le cycle se répète comme indiqué dans le diagramme ci-dessus.

Modèle

Le modèle traite de l'état de l'application. La syntaxe pour définir un modèle est donnée ci-dessous -

-- Model syntax

type alias Model = {
   property1:datatype,
   proptery2:datatype
...
}

Pour créer un modèle, nous devons d'abord créer un modèle avec toutes les propriétés requises. Chaque propriété spécifie l'état de l'application.

Vue

La vue est une représentation visuelle de l'état de l'application. La vue sait comment extraire des données et en générer une page Web. Lorsqu'un utilisateur interagit avec la vue, l'utilisateur peut manipuler l'état en générant des messages. La syntaxe pour définir une vue est donnée ci-dessous -

--View Syntax
view model =some_implementation

Message

Le message est une demande de l'utilisateur pour modifier l'état de l'application. Les messages sont passés en paramètre à la fonction de mise à jour.

--Message Syntax
type Message = Message1 |Message2 ...

La syntaxe montre un type Message. L'application elm modifiera l'état en fonction des messages qui lui sont transmis. Ces décisions sont prises dans la méthode de mise à jour.

Mettre à jour

La fonction de mise à jour interprète les messages, qui lui sont passés en paramètre, et met à jour le modèle.

--Update Syntax
update Message_type model =
   some_implementation

La fonction de mise à jour prend Message et Modéliser comme paramètres.

Un gestionnaire de packages est un outil de ligne de commande qui automatise le processus d'installation, de mise à niveau, de configuration et de suppression de packages dans votre application.

Tout comme JavaScript a un gestionnaire de packages appelé npm, elm a un gestionnaire de packages appelé elm-package .

Le gestionnaire de packages effectue les trois tâches suivantes -

  • Installe toutes les dépendances dont une application elm a besoin
  • Publie des packages personnalisés
  • Détermine la version de votre package lorsque vous êtes prêt à publier et mettre à jour.

Commandes du gestionnaire de packages Elm

Le tableau suivant répertorie les différentes commandes du gestionnaire de packages Elm -

Sr. No. Commander Syntaxe La description
1 installer installation du package elm Installe les packages à utiliser localement
2 publier publication de package elm Publie votre package dans le catalogue central
3 bosse bosse de paquet d'orme Augmente les numéros de version en fonction des modifications de l'API
4 diff elm-package diff Obtient les différences entre deux API

Afin de publier votre package, vous devez héberger le code source sur GitHub et avoir la version correctement étiquetée avec une balise git. L'illustration suivante montre comment utiliser elm-package manager pour extraire une dépendance externe.

Illustration - Installation du package svg

Dans cet exemple, nous verrons comment intégrer Scalable Vector Graphics (SVG) dans une application elm.

Step 1 - Créer un dossier elmSvgApp

Step 2 - Installez le package svg en utilisant la commande suivante -

elm-package install elm-lang/svg

Step 3- Installer Créez un fichier SvgDemo.elm et saisissez le contenu ci-dessous. Nous importons le module Svg pour dessiner un rectangle de dimension 100x100 et remplir la couleur rouge.

import Svg exposing (..)
import Svg.Attributes exposing (..)

main =
   svg
   [ width "120"
   , height "120"
   , viewBox "0 0 120 120"
   ]
   [ rect
      [ x "10"
      , y "10"
      , width "100"
      , height "100"
      , rx "15"
      , ry "15"
      ,fill "red"
      ]
      []
   ]

Step 4- Construisez maintenant le projet en utilisant elm make. \ SvgDemo.elm. Cela générera un index.html comme indiqué ci-dessous -

Le message est un composant de l'architecture Elm. Ces composants sont générés par la vue en réponse à l'interaction de l'utilisateur avec l'interface de l'application. Les messages représentent les demandes des utilisateurs de modifier l'état de l'application.

Syntaxe

--Message Syntax
type Message = some_message1 |some_message2 ...|some_messageN

illustration

L'exemple suivant est une simple application de compteur. L'application incrémente et décrémente la valeur d'une variable de 1 lorsque l'utilisateur clique respectivement sur les boutons Ajouter et Soustraire.

L'application aura 4 composants. Les composants sont décrits ci-dessous -

Message

Les messages de cet exemple seront -

type Message = Add | Subtract

Modèle

Le modèle représente l'état de l'application. Dans l'application de compteur, la définition du modèle est donnée ci-dessous; l'état initial du compteur sera nul.

model = 0

Vue

La vue représente les éléments visuels de l'application. La vue contient deux boutons (+) et (-). Les messages Ajouter et Soustraire sont générés par la Vue lorsque l'utilisateur clique respectivement sur les boutons + et -. La valeur modifiée du modèle est alors affichée par la vue.

view model =
-- invoke text function
h1[]
[   div[] [text "CounterApp from TutorialsPoint" ]
   ,button[onClick Subtract] [text "-"]
   ,div[][text (toString model)]
   ,button[onClick Add] [text "+"]
]

Mettre à jour

Ce composant contient du code qui doit être exécuté pour chaque message généré par la vue. Ceci est illustré dans l'exemple ci-dessous -

update msg model =
case msg of
Add -> model+1
Subtract -> model-1

Mettre tous ensemble

Step 1- Créez un dossier MessagesApp et un fichier MessagesDemo.elm

Step 2 - Ajoutez le code suivant dans le fichier elm -

import Html exposing (..)
import Html.Events exposing(onClick)

model = 0 -- Defining the Model

--Defining the View

view model =
   h1[]
   [  div[] [text "CounterApp from TutorialsPoint" ]
      ,button[onClick Subtract] [text "-"]
      ,div[][text (toString model)]
      ,button[onClick Add] [text "+"]
   ]

--Defining the Messages

type Message = Add | Subtract

--Defining Update

update msg model =
case msg of
   Add -> model+1
   Subtract -> model-1

-- Define the main method
main =
   beginnerProgram
   {
      model=model
      ,view=view
      ,update=update
   }

Step 3 - Exécutez le elm make commanddans le terminal. leelm make command compile le code et génère un fichier HTML à partir du fichier .elm créé ci-dessus.

C:\Users\dell\elm\MessagesApp> elm make .\MessageDemo.elm
Some new packages are needed. Here is the upgrade plan.

   Install:
      elm-lang/core 5.1.1
      elm-lang/html 2.0.0
      elm-lang/virtual-dom 2.0.4

Do you approve of this plan? [Y/n] y
Starting downloads...

   ΓùÅ elm-lang/html 2.0.0
   ΓùÅ elm-lang/virtual-dom 2.0.4

ΓùÅ elm-lang/core 5.1.1
Packages configured successfully!
Success! Compiled 38 modules.
Successfully generated index.html

Step 4 - Ouvrez le index.html et vérifiez le fonctionnement comme indiqué ci-dessous -

Elm - Commandes

Dans les chapitres précédents, nous avons abordé les différents composants de l'architecture Elm et leurs fonctions. L'utilisateur et l'application communiquent entre eux à l'aide de Messages.

Prenons un exemple où l'application a besoin de communiquer avec d'autres composants comme un serveur externe, des API, un microservice, etc. pour répondre à la demande de l'utilisateur. Ceci peut être réalisé en utilisant les commandes dans Elm. Les messages et les commandes ne sont pas synonymes. Les messages représentent la communication entre un utilisateur final et l'application tandis que les commandes représentent la manière dont une application Elm communique avec d'autres entités. Une commande est déclenchée en réponse à un message.

La figure suivante montre le flux de travail d'une application Elm complexe -

L'utilisateur interagit avec la vue. La vue génère un message approprié en fonction de l'action de l'utilisateur. Le composant de mise à jour reçoit ce message et déclenche une commande.

Syntaxe

La syntaxe pour définir une commande est la suivante -

type Cmd msg

Le message généré par la vue est passé à la commande.

Illustration

L'exemple suivant envoie une requête à une API et affiche le résultat de l'API.

L'application accepte un numéro de l'utilisateur, le transmet à l'API Numbers. Cette API renvoie des faits liés au nombre.

Les différents composants de l'application sont les suivants -

Module HTTP

Le module Http d'Elm est utilisé pour créer et envoyer des requêtes HTTP. Ce module ne fait pas partie du module principal. Nous utiliserons le gestionnaire de packages elm pour installer ce package.

API

Dans cet exemple, l'application communiquera avec l'API Numbers - "http://numbersapi.com/#42".

Vue

La vue de l'application contient une zone de texte et un bouton.

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

Modèle

Le modèle représente la valeur saisie par l'utilisateur et le résultat qui sera renvoyé par l'API.

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

Message

L'application a les trois messages suivants -

  • ShowFacts
  • Input
  • NewFactArrived

En cliquant sur le bouton Afficher les faits , le message ShowFacts est transmis à la méthode de mise à jour. Lorsque l'utilisateur tape une valeur dans la zone de texte, le message d' entrée est passé à la méthode de mise à jour. Enfin, lorsque la réponse du serveur Http est reçue, le message NewFactArrived sera transmis à update.

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

Mettre à jour

La méthode update renvoie un tuple, qui contient les objets modèle et commande. Lorsque l'utilisateur clique sur le bouton Afficher les faits, le message est transmis à la mise à jour qui appelle alors 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)

Fonction d'assistance

La fonction d'assistance getRandomNumberFromAPI appelle le NumbersAPI et lui transmet le numéro entré par l'utilisateur. Le résultat renvoyé par l'API est utilisé pour mettre à jour le modèle.

getRadmonNumberFromAPI : String->Cmd Msg
getRadmonNumberFromAPI newNo =
   let
      url =
         "http://numbersapi.com/"++newNo
   in
      Http.send NewFactArrived (Http.getString url)
Sr. No. Méthode Signature La description
1 Http.getString getString: String -> Request String Créez une requête GET et interprétez le corps de la réponse comme une chaîne.
2 Http.send envoyer: (Erreur de résultat a -> msg) -> Request a -> Cmd msg Envoyez une requête Http.

principale

C'est le point d'entrée du projet Elm.

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

Mettre tous ensemble

Step 1 - Créez le dossier CommandApp et le fichier CommandDemo.elm.

Step 2- Installez le module http à l'aide de la commande elm package install elm-lang / http .

Step 2 - Tapez le contenu de CommandDemo.elm comme indiqué ci-dessous -

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 - Lancez la commande.

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

Cela générera le fichier html comme indiqué ci-dessous.

Elm - Abonnements

Dans le chapitre précédent, nous avons expliqué qu'une vue interagit avec d'autres composants à l'aide de commandes. De même, un composant (par exemple WebSocket) peut parler à une vue à l'aide d'abonnements. Les abonnements sont un moyen pour une application Elm de recevoir des entrées externes telles que des événements de clavier, des événements de minuterie et des événements WebSocket.

La figure suivante explique le rôle des abonnements dans une application Elm. L'utilisateur interagit avec une application Elm via des messages. L'application donnée utilise WebSocket et dispose de deux modes de fonctionnement -

  • Envoyer des données côté client au serveur socket via la commande
  • Recevez des données à tout moment du serveur socket via l'abonnement

Syntaxe

La syntaxe pour définir un abonnement est donnée ci-dessous -

type Sub msg

Illustration

Laissez-nous comprendre les abonnements à l'aide d'un exemple simple.

Dans l'exemple ci-dessous, l'application envoie un message au serveur. Le serveur est un serveur d'écho, qui répond au client avec le même message. Tous les messages entrants sont ensuite affichés dans une liste. Nous utiliserons WebSocket (protocole wss) pour être en mesure d'écouter en permanence les messages du serveur. Le WebSocket enverra les entrées utilisateur au serveur à l'aide de commandes tandis qu'il utilisera l'abonnement pour recevoir les messages du serveur.

Les différents composants de l'application sont donnés ci-dessous -

Serveur d'écho

Le serveur d'écho est accessible à l'aide du protocole wss. Le serveur d'écho renvoie l'entrée utilisateur à l'application. Le code pour définir un serveur d'écho est donné ci-dessous -

echoServer : String
echoServer =
"wss://echo.websocket.org"

Modèle

Le modèle représente l'entrée utilisateur et une liste de messages entrants du serveur socket. Le code pour définir le modèle est comme indiqué ci-dessous -

type alias Model =
   { input : String
   , messages : List String
   }

messages

Le type de message contiendra une entrée pour la saisie de texte de l'utilisateur. Le message Envoyer sera généré lorsque l'utilisateur cliquera sur le bouton pour envoyer le message au serveur WebSocket. Le NewMessage est utilisé lorsque le message arrive du serveur d'écho.

type Msg
   = Input String
   | Send
   | NewMessage String

Vue

La vue de l'application contient une zone de texte et un bouton d'envoi pour envoyer les entrées utilisateur au serveur. La réponse du serveur est affichée sur la vue à l'aide d'une balise div .

view : Model -> Html Msg
view model =
   div []
      [ input [onInput Input, value model.input] []
      , button [onClick Send] [text "Send"]
      , div [] (List.map viewMessage (List.reverse model.messages))
      ]

viewMessage : String -> Html msg
viewMessage msg =
   div [] [ text msg ]

Mettre à jour

La fonction de mise à jour prend le message et les composants du modèle. Il met à jour le modèle en fonction du type de message.

update : Msg -> Model -> (Model, Cmd Msg)
update msg {input, messages} =
   case msg of
      Input newInput ->
         (Model newInput messages, Cmd.none)

   Send ->
      (Model "" messages, WebSocket.send echoServer input)

   NewMessage str ->
      (Model input (str :: messages), Cmd.none)
Sr. No. Méthode Signature La description
1 WebSocket.listen Listen: String -> (String -> msg) -> Sous msg S'abonne à tous les messages entrants sur un websocket.
2 WebSocket.send envoyer: Chaîne -> Chaîne -> Cmd msg Envoie une requête wss à une adresse de serveur. Il est important que vous soyez également abonné à cette adresse avec Listen. Si vous ne l'êtes pas, le socket Web sera créé pour envoyer un message, puis fermé.

Abonnement

La fonction d'abonnement prend l'objet de modèle. Pour recevoir les messages du serveur WebSocket, nous appelons WebSocket.listen en transmettant le message en tant que NewMessage . Lorsqu'un nouveau message provient du serveur, la méthode de mise à jour est appelée.

subscriptions : Model -> Sub Msg
subscriptions model =
WebSocket.listen echoServer NewMessage

principale

La fonction principale est le point d'entrée de l'application elm comme indiqué ci-dessous.

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

Mettre tous ensemble

Step 1 - Créez un répertoire, SubscriptionApp et ajoutez-y un fichier, SubscriptionDemo.elm.

Step 2 - Ajoutez le contenu suivant au fichier SubscriptionDemo.elm -

import Html exposing (..)
import Html.Attributes exposing (..)
import Html.Events exposing (..)
import WebSocket

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

echoServer : String
echoServer =
   "wss://echo.websocket.org"

-- MODEL

type alias Model =
   { input : String
   , messages : List String
   }

init : (Model, Cmd Msg)
init =
   (Model "" [], Cmd.none)

-- UPDATE
type Msg
   = Input String
   | Send
   | NewMessage String

update : Msg -> Model -> (Model, Cmd Msg)
update msg {input, messages} =
   case msg of
      Input newInput ->
      (Model newInput messages, Cmd.none)

   Send ->
      (Model "" messages, WebSocket.send echoServer input)

   NewMessage str ->
      (Model input (str :: messages), Cmd.none)

-- SUBSCRIPTIONS
subscriptions : Model -> Sub Msg
subscriptions model =
   WebSocket.listen echoServer NewMessage

-- VIEW
view : Model -> Html Msg
view model =
   div []
      [ input [onInput Input, value model.input] []
      , button [onClick Send] [text "Send"]
      , div [] (List.map viewMessage (List.reverse model.messages))
      ]

viewMessage : String -> Html msg
viewMessage msg =
div [] [ text msg ]

Step 3 - Installez le package websockets à l'aide du gestionnaire de packages elm.

C:\Users\dell\elm\SubscriptionApp> elm-package install elm-lang/websocket

Step 4 - Créez et générez le fichier index.html comme indiqué ci-dessous.

C:\Users\dell\elm\SubscriptionApp> elm make .\SubscriptionDemo.elm

Step 5 - Lors de l'exécution, la sortie suivante sera générée -