참고
더보기
Spring Boot & Thymeleaf 시리즈는 김영한 님의 "스프링 MVC 2편 - 백엔드 웹 개발 활용 기술" 강의를 정리한 글입니다. 글에 첨부된 사진은 해당 강의의 강의 자료에서 캡쳐한 것입니다. 제 Github에만 올려뒀다가, 정보 공유와 강의 홍보(?)를 위해 블로그에도 업로드합니다.
스프링 MVC 2편 - 백엔드 웹 개발 활용 기술 - 인프런 | 강의
웹 애플리케이션 개발에 필요한 모든 웹 기술을 기초부터 이해하고, 완성할 수 있습니다. MVC 2편에서는 MVC 1편의 핵심 원리와 구조 위에 실무 웹 개발에 필요한 모든 활용 기술들을 학습할 수 있
www.inflearn.com
마크다운 형식으로 작성한 글을 블로그에 다시 올리는 거라 가독성이 많이 떨어집니다. 조금더 편하게 보시려면 아래의 Github repository에서 보시면 됩니다.
GitHub - Kloong1/TIL: Today I Learned.
Today I Learned. Contribute to Kloong1/TIL development by creating an account on GitHub.
github.com
타임리프 - 변수, SpringEL
변수 표현식과 SpringEL
- 타임리프에서 변수를 사용할 때는 변수 표현식을 사용한다.
- 변수 표현식:
${...}
- 이 변수 표현식에서 SpringEL이라는 스프링이 제공하는 표현식을 사용할 수 있다.
BasicController.java 내용 추가
package kloong.thymeleaf.basic;
import ... //생략
@Controller
@RequestMapping("/basic")
public class BasicController {
@GetMapping("/variable")
public String variable(Model model) {
User userA = new User("userA", 10);
User userB = new User("userB", 20);
List<User> list = new ArrayList<>();
list.add(userA);
list.add(userB);
Map<String, User> map = new HashMap<>();
map.put("userA", userA);
map.put("userB", userB);
model.addAttribute("user", userA);
model.addAttribute("users", list);
model.addAttribute("userMap", map);
return "basic/variable";
}
@Data
static class User {
private String username;
private int age;
public User(String username, int age) {
this.username = username;
this.age = age;
}
}
}
- 모델에
User
객체,List<User>
,Map<String, User>
를 추가해서 넘겼다.
/resources/templates/basic/variable.html
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>SpringEL 표현식</h1>
<ul>Object
<li>${user.username} = <span th:text="${user.username}"></span></li>
<li>${user['username']} = <span th:text="${user['username']}"></span></li>
<li>${user.getUsername()} = <span th:text="${user.getUsername()}"></span></li>
</ul>
<ul>List
<li>${users[0].username} = <span th:text="${users[0].username}"></span></li>
<li>${users[0]['username']} = <span th:text="${users[0]['username']}"></span></li>
<li>${users[0].getUsername()} = <span th:text="${users[0].getUsername()}"></span></li>
<li>${users[1].username} = <span th:text="${users[1].username}"></span></li>
<li>${users[1]['username']} = <span th:text="${users[1]['username']}"></span></li>
<li>${users[1].getUsername()} = <span th:text="${users[1].getUsername()}"></span></li>
</ul>
<ul>Map
<li>${userMap['userA'].username} = <span th:text="${userMap['userA'].username}"></span></li>
<li>${userMap['userA']['username']} = <span th:text="${userMap['userA']['username']}"></span></li>
<li>${userMap['userA'].getUsername()} = <span th:text="${userMap['userA'].getUsername()}"></span></li>
<li>${userMap['userB'].username} = <span th:text="${userMap['userB'].username}"></span></li>
<li>${userMap['userB']['username']} = <span th:text="${userMap['userB']['username']}"></span></li>
<li>${userMap['userB'].getUsername()} = <span th:text="${userMap['userB'].getUsername()}"></span></li>
</ul>
</body>
</html>
Spring에서 지원하는 SpringEL 표현식을 사용 가능
Object
user.username
- user의 username을 프로퍼티 방식으로 접근
user.getUsername()
을 호출해서 값을 받아온다.
user['username']
- 마찬가지로
user.getUsername()
을 호출해서 값을 받아온다. - 문자열 형태의 값을 사용하기 때문에 동적으로 값을 가져오는 데 사용할 수 있다.
- 마찬가지로
user.getUsername()
- user의
getUsername()
을 직접 호출
- user의
List
users[0].username
- List에서 첫 번째 요소를 찾고, username 프로퍼티 접근
list.get(0).getUsername()
users[0]['username']
- 위와 같음
users[0].getUsername()
- List에서 첫 번째 회원을 찾고 getter 직접 호출
Map
userMap['userA'].username
- Map에서
userA
key에 해당하는 원소를 찾고, username 프로퍼티 접근 map.get("userA").getUsername()
- Map에서
userMap['userA']['username']
- 위와 같음
userMap['userA'].getUsername()
- Map에서
userA
key에 해당하는 원소를 찾아 getter 직접 호출
- Map에서
타임리프에서 지역 변수 선언
th:with
를 사용하면 지역 변수를 선언해서 사용할 수 있다.- 지역 변수는 선언한 태그 안에서만 유효하다.
<h1>지역 변수 - (th:with)</h1>
<div th:with="first=${users[0]}">
<p>처음 사람의 이름은 <span th:text="${first.username}"></span></p>
</div>
th:with
로first
라는 지역 변수를 선언했다.first
는users
list의 첫 번째 값을 가진다.- 즉
first
는User
객체를 가리키게 된다.
'Spring > Spring Boot & Thymeleaf' 카테고리의 다른 글
[Spring Boot & Thymeleaf] 6. URL 링크 (0) | 2022.09.05 |
---|---|
[Spring Boot & Thymeleaf] 5. 유틸리티 객체와 날짜 다루기 (0) | 2022.09.05 |
[Spring Boot & Thymeleaf] 4. 기본 객체들 (1) | 2022.09.05 |
[Spring Boot & Thymeleaf] 2. text & utext, Escape (0) | 2022.09.05 |
[Spring Boot & Thymeleaf] 1. Thymeleaf 소개 (0) | 2022.09.05 |
댓글