Commandoregelargumenten lezen

Elm:
Commandoregelargumenten lezen

Hoe:

Elm draait in de browser, dus het heeft geen directe toegang tot opdrachtregelargumenten zoals een traditionele server-side of desktop taal dat wel heeft. Echter, ter illustratie, laten we aannemen dat je Elm gebruikt met een server-side framework zoals Node.js via elm server of een vergelijkbare opstelling die het doorgeven van argumenten mogelijk maakt. Je code zal de argumenten niet direct afhandelen, maar we zullen het patroon nabootsen:

-- Veronderstel binnenkomende argumenten van server-side
type alias Flags = 
    { arg1 : String
    , arg2 : Int
    }

-- Voorbeeld Elm `init` functie gebruikmakend van Flags
init : Flags -> ( Model, Cmd Msg )
init flags =
    ( { defaultModel | passedArg1 = flags.arg1, passedArg2 = flags.arg2 }
    , Cmd.none
    )

Voorbeelduitvoer (gestructureerd alsof doorgegeven door de server):

{ "arg1": "Hallo", "arg2": 42 }

Diepere Duik

Aangezien Elm een frontend taal is, gaat het traditioneel niet om met opdrachtregelargumenten. Elm werkt in de gecontroleerde omgeving van de browser. De opdrachtregel is een overblijfsel uit de vroege dagen van de informatica, dienend als een venster naar het systeem.

In Node.js of vergelijkbare omgevingen, zou je typisch process.argv gebruiken om argumenten te krijgen. Met Elm kom je het dichtst in de buurt met vlaggen wanneer je je Elm-app initialiseert vanuit JavaScript, wat het injecteren van externe data mogelijk maakt. Je accepteert opdrachtregelargumenten indirect via de server-side taal, en vervolgens geef je ze door aan Elm als vlaggen.

Voor diepe integratie, worden Elm-apps gebundeld met server-side code, wat een naadloze ervaring aan gebruikers biedt. Dit patroon van het starten van een Elm programma met specifieke vlaggen is krachtig; het staat toe voor flexibele, dynamische initialisatie die zich aanpast aan verschillende omgevingen en gebruiksscenario’s.

Zie Ook