Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
J
javab_20230928
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Patryk Czarnik
javab_20230928
Commits
471b8b2e
Commit
471b8b2e
authored
Oct 19, 2023
by
Patryk Czarnik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
TimeController - wersje z szablonami
parent
7381a89d
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
106 additions
and
0 deletions
+106
-0
TimeController.java
...Spring/src/main/java/com/example/demo/TimeController.java
+38
-0
wyswietl_czas5.html
PC26-Spring/src/main/resources/templates/wyswietl_czas5.html
+14
-0
wyswietl_czas6.html
PC26-Spring/src/main/resources/templates/wyswietl_czas6.html
+54
-0
No files found.
PC26-Spring/src/main/java/com/example/demo/TimeController.java
View file @
471b8b2e
package
com
.
example
.
demo
;
import
java.time.LocalDate
;
import
java.time.LocalDateTime
;
import
java.time.LocalTime
;
import
java.time.format.DateTimeFormatter
;
import
java.util.ArrayList
;
import
java.util.List
;
import
java.util.Locale
;
import
org.springframework.stereotype.Controller
;
import
org.springframework.ui.Model
;
import
org.springframework.web.bind.annotation.GetMapping
;
import
org.springframework.web.bind.annotation.ResponseBody
;
@Controller
public
class
TimeController
{
// Spring MVC
@GetMapping
(
"/time1"
)
@ResponseBody
...
...
@@ -55,6 +60,39 @@ public class TimeController {
dt
.
toLocalTime
(),
dt
.
toLocalDate
(),
dt
.
format
(
FORMAT_DATY
));
}
// 2. Tworzymy odpowiedź za pomocą "szablonu" z wykorzystaniem dodatkowej technologii,
// tutaj jest to Thymeleaf, ale może być coś innego: JSP, Velocity, FreeMarker, Mustache, ...
// Gdy metoda w kontrolerze w wyniku zwraca String, a nie posiada adnotacji @ResponseBody,
// to Spring traktuje zwracaną wartość jak nazwę szablonu,
// w odp. miejscu szuka pliku z szablonem i generuje wynik za pomocą tego szablonu.
// Gdy do szablonu chcemy przekazać jakieś dane, to dodajemy je jako atrybuty do modelu.
// Najprościej zrobić to poprzez parametr model.
@GetMapping
(
"/time5"
)
public
String
time5
(
Model
model
)
{
LocalDateTime
dataCzas
=
LocalDateTime
.
now
();
model
.
addAttribute
(
"dt"
,
dataCzas
);
return
"wyswietl_czas5.html"
;
}
// Przykład pokazujący dalsze możliwości Thymeleaf.
// https://www.thymeleaf.org/
@GetMapping
(
"/time6"
)
public
String
time6
(
Model
model
)
{
LocalDateTime
dt
=
LocalDateTime
.
now
();
model
.
addAttribute
(
"dt"
,
dt
);
List
<
LocalDate
>
dates
=
new
ArrayList
<>();
LocalDate
date
=
dt
.
toLocalDate
();
for
(
int
i
=
0
;
i
<=
5
;
i
++)
{
dates
.
add
(
date
.
plusWeeks
(
i
));
}
model
.
addAttribute
(
"futureWeeks"
,
dates
);
return
"wyswietl_czas6.html"
;
}
}
PC26-Spring/src/main/resources/templates/wyswietl_czas5.html
0 → 100644
View file @
471b8b2e
<!DOCTYPE html>
<html>
<head>
<meta
charset=
"UTF-8"
>
<title>
Bieżąca godzina
</title>
</head>
<body>
<p>
Zaraz powiem, która godzina…
</p>
<p>
Wartość obiektu
<code>
dt
</code>
: [[${dt}]]
</p>
<p>
Sekunda: [[${dt.second}]]
</p>
<p>
Dzień roku: [[${dt.dayOfYear}]]
</p>
</body>
</html>
PC26-Spring/src/main/resources/templates/wyswietl_czas6.html
0 → 100644
View file @
471b8b2e
<!DOCTYPE html>
<html
lang=
"pl"
xmlns:th=
"http://www.thymeleaf.org"
>
<head>
<meta
charset=
"UTF-8"
>
<title>
Show Time 6
</title>
<link
rel=
"stylesheet"
type=
"text/css"
th:href=
"@{/styl.css}"
href=
"../static/styl.css"
>
</head>
<body>
<h1>
Data i czas
</h1>
<h3>
Trzy sposoby wstawiania wartości atrybutu w Thymeleaf
</h3>
<ul>
<!-- th:text oraz data-th-text to są przykłady podejścia "natural template",
czyli że plik jest poprawnym składniowo dokumentem HTML, a dodatkowe magiczne atrybuty powodują specjalne działanie"
gdy ten plik jest przetwarzany przez "silnik thymeleaf".
-->
<!-- Najbardziej zalecane podejście: dodatkowa przestrzeń nazw th
Aby to zadziałało, w HTMLu (najczęściej na samym początku) musi byś zadeklarowana przestrzeń nazw.
"Tekst, który znajduje się wewnątrz znacznika, zastąp wartością zmiennej dt"
-->
<li
th:text=
"${dt}"
>
jakaś godzina 1
</li>
<!-- atrybuty "data" wprowadzone w HTML 5
Normalnie takich atrybutów używają skrypty JS, aby w dokumencie zapamiętywać dane,
a tutaj Thymeleaf używa w innym celu.
-->
<li
data-th-text=
"${dt}"
>
jakaś godzina 2
</li>
<!-- zagnieżdżone wyrażenia / inline expressions - podejście podobne do JSP, tutaj mniej zalecane -->
<li>
to jest wynik: [[${dt}]]
</li>
</ul>
<h3>
Odwołania do elementów zagnieżdżonych
</h3>
<ul>
<!-- tak naprawdę wywołanie dt.getYear() -->
<li>
rok:
<strong
th:text=
"${dt.year}"
>
1997
</strong></li>
<li>
dzień roku:
<strong
th:text=
"${dt.dayOfYear}"
>
100
</strong></li>
<li>
dzień tygodnia:
<strong
th:text=
"${dt.dayOfWeek}"
>
MONDAY
</strong></li>
<li>
sekunda:
<strong
th:text=
"${dt.second}"
>
33
</strong></li>
<!-- Można też wywołać metodę, która coś odczyta, nawet jeśli nie nazywa się getXXX() -->
<li>
data:
<strong
th:text=
"${dt.toLocalDate()}"
>
2020-04-05
</strong></li>
<li>
czas:
<strong
th:text=
"${dt.toLocalTime()}"
>
10:44:22
</strong></li>
</ul>
<h3>
Odczyt elementów listy
</h3>
<p>
Ten sam dzień w kolejnych tygodniach:
</p>
<ol
start=
"0"
>
<li
th:each=
"date : ${futureWeeks}"
th:text=
"${date}"
>
2022-08-01
</li>
</ol>
</body>
</html>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment