programmeren
in python
Jaar 4 - Module 1 - Les 3: Templates in Flask & Dictionaries
Dit jaar gaan we...
-
Leren hoe websites werken
-
Wat het verschil is tussen server & client software
Dit jaar gaan we...
-
Leren hoe websites werken
-
Wat het verschil is tussen server & client software
-
Zelf een website maken met Python, HTML & Javascript
-
Voor jezelf, of voor een eigen klant
De komende weken gaan we...
-
Leren hoe websites werken
-
Zelf een website maken met Python
-
Python kennis opfrissen en verdiepen
vandaag gaan we leren
-
Wat een dictionary is in Python
-
Hoe je een template gebruikt in Flask
Dit programma gebruikt een lijst.
Lijsten (herhaling)
In een lijst halen we een element op met een numerieke index, oftewel, een getal.
dieren = ['schildpad', 'kikker']
print(dieren[0])
Dit programma gebruikt een lijst.
Lijsten (herhaling)
In een lijst halen we een element op met een numerieke index, oftewel, een getal.
Bij een lange lijst is dat niet zo handig.
dieren = ['schildpad', 'kikker', 'hagedis', 'blobvis', 'hinde', ...]
print(dieren[15])
Dit programma gebruikt een lijst.
Lijsten (herhaling)
In een lijst halen we een element op met een numerieke index, oftewel, een getal.
Bij een lange lijst is dat niet zo handig. Als we veel dingen van verschillende soorten opslaan, gebruiken we liever een dictionary.
dieren = ['schildpad', 'kikker', 'hagedis', 'blobvis', 'hinde', ...]
print(dieren[15])
Dit programma gebruikt een dictionary.
Dictionaries
Dit programma gebruikt een dictionary.
Dictionaries
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dit programma gebruikt een dictionary.
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dictionaries
Aanwijzen lijkt op aanwijzen bij een lijst, maar met een naam ipv een getal
Dit programma gebruikt een dictionary.
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dictionaries
Aanwijzen lijkt op aanwijzen bij een lijst, maar met een naam ipv een getal
De naam is een string dus aanhalingstekens zijn nodig
Dit programma gebruikt een dictionary.
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dictionaries
Instellen gaat anders dan bij een lijst
Dit programma gebruikt een dictionary.
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dictionaries
Instellen gaat anders dan bij een lijst
Ieder veld of field krijgt een naam, altijd een string
Dus ook hier aanhalingstekens!
Dit programma gebruikt een dictionary.
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dictionaries
Instellen gaat anders dan bij een lijst
Ieder veld of field krijgt een naam, altijd een string
Na het veld komt een dubbele punt
Dit programma gebruikt een dictionary.
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dictionaries
Instellen gaat anders dan bij een lijst
Ieder veld of field krijgt een naam, altijd een string
Na het veld komt een dubbele punt
Dan komt de waarde, dan ieder Python type zijn
Dit programma gebruikt een dictionary.
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dictionaries
Instellen gaat anders dan bij een lijst
Ieder veld of field krijgt een naam, altijd een string
Na het veld komt een dubbele punt
Dan komt de waarde, dan ieder Python type zijn
Een string mag
Dit programma gebruikt een dictionary.
gebruiker = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print(gebruiker['voornaam'])
Dictionaries
Instellen gaat anders dan bij een lijst
Ieder veld of field krijgt een naam, altijd een string
Na het veld komt een dubbele punt
Dan komt de waarde, dan ieder Python type zijn
Een getal mag ook!
demo
goed of fout?
gebruiker = {
voornaam: 'Piet',
achternaam: 'de Vries',
geboortejaar: 2000
}
print(gebruiker['voornaam'])
- Is de code goed -> schrijf wat de code print
- Is de code fout? -> schrijf FOUT
goed of fout?
'gebruiker' = {
'voornaam': 'Piet',
'achternaam': 'de Vries',
'geboortejaar': 2000
}
print('gebruiker'['voornaam'])
- Is de code goed -> schrijf wat de code print
- Is de code fout? -> schrijf FOUT
goed of fout?
adres_blaak = {
'straat': 'Blaak',
'nummer': 166
}
gebruiker = {
'voornaam': 'Carl',
'achternaam': 'Johnsons',
'adres': adres_blaak
}
print(gebruiker['voornaam'])
- Is de code goed -> schrijf wat de code print
- Is de code fout? -> schrijf FOUT
goed of fout?
adres_blaak = {
'straat': 'Blaak',
'nummer': 166
}
gebruiker = {
'voornaam': 'Carl',
'achternaam': 'Johnsons',
'adres': adres_blaak
}
print(gebruiker['adres']['straat'])
- Is de code goed -> schrijf wat de code print
- Is de code fout? -> schrijf FOUT
HTML is de codetaal die bepaalt hoe websites eruit zien.
HTML
HTML is de codetaal die bepaalt hoe websites eruit zien.
HTML
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo allemaal!
<p> Welkom </p>
</body>
</html>
HTML is de codetaal die bepaalt hoe websites eruit zien.
HTML
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo allemaal!
<p> Welkom </p>
</body>
</html>
Maar... een HTML pagina is "statisch".
HTML is de codetaal die bepaalt hoe websites eruit zien.
HTML
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo allemaal!
<p> Welkom </p>
</body>
</html>
Maar... een HTML pagina is "statisch".
Statisch betekent dat de pagina altijd hetzelfde is, en niet kan veranderen door een actie van de gebruiker.
HTML is de codetaal die bepaalt hoe websites eruit zien.
HTML
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo allemaal!
<p> Welkom </p>
</body>
</html>
Maar... een HTML pagina is "statisch".
Statisch betekent dat de pagina altijd hetzelfde is, en niet kan veranderen door een actie van de gebruiker.
Flask zorgt ervoor dat pagina's wel dynamisch worden, met templates.
Met Flask mag je variabelen
invoegen in een HTML pagina.
HTML & Flask
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo allemaal!
<p> Welkom </p>
</body>
</html>
Met Flask mag je variabelen
invoegen in een HTML pagina.
Dat doen we met dubbele krulhaakjes!
HTML & Flask
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo {{name}}!
<p> Welkom </p>
</body>
</html>
HTML & Flask
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo {{name}}!
<p> Welkom </p>
</body>
</html>
Met Flask mag je variabelen
invoegen in een HTML pagina.
Dat doen we met dubbele krulhaakjes!
Vanuit Flask geef je de variabele mee aan het template.
Even opfrissen!
HTML & Flask
@app.route('/')
def hello():
return "Hallo leerlingen!"
Even opfrissen!
HTML & Flask
@app.route('/')
def hello():
return "Hallo leerlingen!"
Welke pagina wordt er geladen?
Even opfrissen!
HTML & Flask
@app.route('/')
def hello():
return "Hallo leerlingen!"
Dit is ons antwoord
demo
Flask kan ook een variabele uit de URL halen.
HTML & Flask
# Parameter example
@app.route('/hello/<string:name>')
def hello_name(name):
return "Hallo " + name
Flask kan ook een variabele uit de URL halen.
HTML & Flask
Welke pagina wordt er geladen?
# Parameter example
@app.route('/hello/<string:name>')
def hello_name(name):
return "Hallo " + name
Flask kan ook een variabele uit de URL halen.
HTML & Flask
De tekst achter de slash
komt in de variabele name
# Parameter example
@app.route('/hello/<string:name>')
def hello_name(name):
return "Hallo " + name
Flask kan ook een variabele uit de URL halen.
HTML & Flask
# Parameter example
@app.route('/hello/<string:name>')
def hello_name(name):
return "Hallo " + name
Flask kan die variabele gebruiken
demo
HTML & Flask
# Parameter example
@app.route('/hello/<string:name>')
def hello_name(name):
return "<b>Hallo " + name + "</b>"
We kunnen hier dus ook HTML code neerzetten.
HTML & Flask
# Parameter example
@app.route('/hello/<string:name>')
def hello_name(name):
return "<b>Hallo " + name + "</b>"
We kunnen hier dus ook HTML code neerzetten.
Maar, dat wordt snel een rommeltje.
We werken liever met templates.
HTML & Flask
@app.route('/hello_template/<string:name>')
def hello_template(name):
return render_template('front_page.html',name=name)
Geef een template als antwoord
HTML & Flask
@app.route('/hello_template/<string:name>')
def hello_template(name):
return render_template('front_page.html',name=name)
Het template front_page.html
HTML & Flask
@app.route('/hello_template/<string:name>')
def hello_template(name):
return render_template('front_page.html',name=name)
Het template front_page.html
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo {{name}}!
<p> Welkom </p>
</body>
</html>
HTML & Flask
@app.route('/hello_template/<string:name>')
def hello_template(name):
return render_template('front_page.html',name=name)
Variabele name in het template wordt de name uit de url
<!DOCTYPE html>
<html>
<head>
<title>Welkom op deze site!</title>
</head>
<body>
Hallo {{name}}!
<p> Welkom </p>
</body>
</html>
demo
Flask in repl.it
Maak hier een nieuwe map
Flask in repl.it
Maak hier een nieuw HTML bestand
opdrachten
opdrachten
- Volg deze HTML/Flask les: bit.ly/flask-templates
opdrachten
- Volg deze HTML/Flask les: bit.ly/flask-templates
- Gebruik templates op jouw site
opdrachten
- Volg deze HTML/Flask les: bit.ly/flask-templates
- Gebruik templates op jouw site
Klas 4 - Module 1 - Les 3
By Felienne
Klas 4 - Module 1 - Les 3
Leerdoel Module: Website maken met Flask Lesdoel: Begin dictionaries.
- 794