Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
alx_mszczonow_3
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
alx_mszczonow_3
Commits
7eaaf33a
Commit
7eaaf33a
authored
Jul 25, 2023
by
Patryk Czarnik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
time6
parent
ab9ee12b
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
83 additions
and
2 deletions
+83
-2
TimeController.java
src/main/java/alx/TimeController.java
+29
-2
szablon6.html
src/main/resources/templates/szablon6.html
+54
-0
No files found.
src/main/java/alx/TimeController.java
View file @
7eaaf33a
...
...
@@ -5,8 +5,11 @@ import org.springframework.ui.Model;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.ResponseBody
;
import
java.time.LocalDate
;
import
java.time.LocalDateTime
;
import
java.time.format.DateTimeFormatter
;
import
java.util.ArrayList
;
import
java.util.List
;
import
java.util.Locale
;
@Controller
...
...
@@ -53,11 +56,35 @@ 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.
@RequestMapping
(
"/time5"
)
public
String
time5
(
Model
model
)
{
public
String
time5
(
Model
model
)
{
// IoC inversion of control
LocalDateTime
dateTime
=
LocalDateTime
.
now
();
model
.
addAttribute
(
"dt"
,
dateTime
);
return
"szablon5.html"
;
return
"wyswietl_czas5.html"
;
}
@RequestMapping
(
"/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
"szablon6.html"
;
}
}
src/main/resources/templates/szablon6.html
0 → 100644
View file @
7eaaf33a
<!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