I den forrige artikel i dette række artikler, vi talte om, hvad Sinatra er. I denne artikel skal vi se på nogle rigtige funktionelle Sinatra-koder ved at berøre et par Sinatra-funktioner, som alle vil blive udforsket i dybden i kommende artikler i denne serie.
Inden du kommer i gang, skal du gå foran og installere Sinatra. Installation af Sinatra er lige så let som enhver anden perle. Sinatra har nogle få afhængigheder, men intet større, og du skal ikke have problemer med at installere det på nogen platform.
$ perle installere sinatra
Hej Verden!
Sinatra-applikationen "Hello world" er chokerende enkel. Ikke inklusive krævede linjer, shebang og hvidafstand, det er kun tre linjer. Dette er ikke kun en lille del af din applikation, ligesom en controller i en Rails-applikation, dette er det hele. En anden ting, du muligvis bemærker, er, at du ikke havde brug for at køre noget som Rails-generatoren for at generere en applikation. Bare indsæt følgende kode i en ny Ruby-fil, så er du færdig.
#! / usr / bin / env ruby
kræver 'rubygemer'
kræver 'sinatra'
få '/' gøre
'Hej Verden!'
ende
Naturligvis er dette ikke et meget nyttigt program, det er bare "Hej verden", men endnu mere nyttige applikationer i Sinatra er ikke meget større. Så hvordan kører du denne lille webapplikation? En slags kompleks script / server kommando? Nej, bare kør filen. Det er bare et Ruby-program, kør det!
inatra $ ./hello.rb
== Sinatra / 0.9.4 har taget scenen i 4567 til udvikling med backup fra Mongrel
Ikke meget spændende endnu. Det er startet serveren og bundet til port 4567, så gå videre og peg din webbrowser til http://localhost: 4567/. Der er din "Hello world" -meddelelse. Webapplikationer har aldrig været så nemt i Ruby før.
Brug af parametre
Så lad os se på noget lidt mere interessant. Lad os lave en applikation, der hilser dig ved navn. For at gøre dette skal vi bruge en parameter. Parametre i Sinatra er som alt andet - enkle og ligetil.
#! / usr / bin / env ruby
kræver 'rubygemer'
kræver 'sinatra'
get '/ hallo /: name' do
"Hej # {params [: navn]}!"
ende
Når du har foretaget denne ændring, skal du genstarte Sinatra-applikationen. Dræb det med Ctrl-C og kør det igen. (Der er en måde at omgå dette på, men vi vil se på det i en fremtidig artikel.) Nu er parametrene ligetil. Vi har lavet en handling kaldet /hello/:name. Denne syntaks imiterer, hvordan webadresserne ser ud, så gå til http://localhost: 4567 / hej / dit navn at se det i handling.
Det /hello del matcher den del af URL'en fra det spørgsmål, du har oprettet, og :navn vil absorbere enhver anden tekst, du giver den og lægge den i params hash under nøglen :navn. Parametre er lige så nemme. Der er selvfølgelig meget mere, du kan gøre med disse, inklusive regexp-baserede parametre, men det er alt hvad du har brug for i næsten hvert tilfælde.
Tilføjelse af HTML
Endelig, lad os sprede denne applikation op med en smule HTML. Sinatra returnerer, hvad det får fra din URL-handler til webbrowseren. Indtil videre har vi netop returneret en streng tekst, men vi kan tilføje noget HTML derinde uden problemer. Vi bruger ERB her, ligesom det bruges i Rails. Der er andre (tvivlsomt bedre) muligheder, men dette er måske det mest kendte, da det kommer med Ruby, og det vil gå fint her.
Først gengiver Sinatra et kaldet synspunkt layout hvis der findes en. Denne layoutvisning skal have en udbytte udmelding. Denne afkastopgørelse vil fange output fra den specifikke visning, der gengives. Dette giver dig mulighed for at oprette layouts meget enkelt. Endelig har vi en Hej visning, der genererer den faktiske hejmeddelelse. Dette er det synspunkt, der blev gengivet ved hjælp af erb: hej metodeopkald. Du vil bemærke, at der ikke er separate visningsfiler. Der kan være, men for en sådan lille applikation er det bedst at opbevare al koden i en enkelt fil. Selvom visningerne er sepeated i slutningen af filen.
#! / usr / bin / env ruby
kræver 'rubygemer'
kræver 'sinatra'
get '/ hallo /: name' do
@name = params [: name]
erb: hej
ende
__ENDE__
@@ layout
@@ HejHej !
Og der har du det. Vi har en komplet, funktionel hej verden applikation i cirka 15 kodelinjer inklusive udsigterne. De følgende artikler skal vi se nærmere på ruterne, hvordan du kan gemme og hente data, og hvordan man får bedre visninger med HAML.