Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
J
java_dzienna_15_09
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
java_dzienna_15_09
Commits
b5f1cbef
Commit
b5f1cbef
authored
Sep 30, 2022
by
Patryk Czarnik
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
show_time6
parent
24c20f31
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
100 additions
and
0 deletions
+100
-0
DateTimeController.java
...ng/src/main/java/com/example/demo/DateTimeController.java
+16
-0
styl.css
PC29-Spring/src/main/resources/static/styl.css
+36
-0
show_time6.html
PC29-Spring/src/main/resources/templates/show_time6.html
+48
-0
No files found.
PC29-Spring/src/main/java/com/example/demo/DateTimeController.java
View file @
b5f1cbef
...
...
@@ -49,6 +49,15 @@ public class DateTimeController {
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
)
{
LocalDateTime
dt
=
LocalDateTime
.
now
();
...
...
@@ -57,4 +66,11 @@ public class DateTimeController {
return
"show_time5.html"
;
}
@RequestMapping
(
"/time6"
)
public
String
time6
(
Model
model
)
{
LocalDateTime
dt
=
LocalDateTime
.
now
();
model
.
addAttribute
(
"dt"
,
dt
);
return
"show_time6.html"
;
}
}
PC29-Spring/src/main/resources/static/styl.css
0 → 100644
View file @
b5f1cbef
body
{
background-color
:
#FFFFCC
;
font-family
:
'Arial'
,
sans-serif
;
}
h1
{
color
:
green
;
text-align
:
center
;
}
form
{
margin
:
30px
auto
;
padding
:
20px
;
width
:
800px
;
border
:
4px
solid
blue
;
background-color
:
#AAEEFF
;
}
.wynik
{
background-color
:
#FFFFFF
;
border
:
3px
solid
green
;
margin
:
20px
auto
;
width
:
800px
;
padding
:
10px
;
color
:
green
;
}
.error
{
background-color
:
#FFFFFF
;
border
:
6px
double
red
;
margin
:
20px
auto
;
padding
:
10px
;
width
:
800px
;
color
:
red
;
font-weight
:
bold
;
}
PC29-Spring/src/main/resources/templates/show_time6.html
0 → 100644
View file @
b5f1cbef
<!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>
</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