4. JAVA

[Thymeleaf] 유틸함수(#numbers,#strings,#arrays,#lists 등)

자르르 2023. 11. 8. 13:34

타임리프에서는 효율적인 오브젝트 사용을 위해 기본적인 오브젝트 유틸리티를 제공하고 있다. 

타임리프의 기본 제공 유틸리티 함수는 다음과 같다.

  • #numbers
  • #strings
  • #arrays
  • #lists
  • #sets
  • #maps
  • #objects
  • #bools
  • #dates
  • #calendars
  • #uris
  • #messages
  • #conversions
  • #aggregates
  • #ids

다음 중 자주 사용하는 주요 함수만 정리하도록 하겠다.

 

numbers

종류 설명
${#numbers.formatInteger(num,3)}
${#numbers.arrayFormatInteger(numArray,3)}
${#numbers.listFormatInteger(numList,3)}
${#numbers.setFormatInteger(numSet,3)}
자리수를 설정한 숫자 포맷 적용
ex) formatInteger(15, 3) 
→ 015
${#numbers.formatInteger(num,3,'POINT')}
${#numbers.arrayFormatInteger(numArray,3,'POINT')}
${#numbers.listFormatInteger(numList,3,'POINT')}
${#numbers.setFormatInteger(numSet,3,'POINT')}
숫자 포맷 적용하되 자릿수마다 구분점 표시 가능
구분자 : COMMA, POINT, WHITESPACE, NONE, DEFAULT
ex) formatInteger(123123,3,'COMMA')
→ 123,123
${#numbers.formatDecimal(num,3,2)}
${#numbers.arrayFormatDecimal(numArray,3,2)}
${#numbers.listFormatDecimal(numList,3,2)}
${#numbers.setFormatDecimal(numSet,3,2)}
자리수를 설정한 소수 포맷 적용 
ex) formatDecimal(51.3, 3, 2)
→ 051.30
${#numbers.formatDecimal(num,3,2,'COMMA')}
${#numbers.arrayFormatDecimal(numArray,3,2,'COMMA')}
${#numbers.listFormatDecimal(numList,3,2,'COMMA')}
${#numbers.setFormatDecimal(numSet,3,2,'COMMA')}
소수 포맷 적용하되 자릿수마다 구분점 표시 가능
ex) formatDecimal(123123.54, 3, 2,'COMMA')
→ 123,123.54
${#numbers.formatDecimal(num,3,'POINT',2,'COMMA')}
${#numbers.arrayFormatDecimal(numArray,3,'POINT',2,'COMMA')}
${#numbers.listFormatDecimal(numList,3,'POINT',2,'COMMA')}
${#numbers.setFormatDecimal(numSet,3,'POINT',2,'COMMA')}
정수부분 소수부분 각각 자릿수마다 구분점 표시 가능
${#numbers.formatCurrency(num)}
${#numbers.arrayFormatCurrency(numArray)}
${#numbers.listFormatCurrency(numList)}
${#numbers.setFormatCurrency(numSet)}
통화 포맷 적용
${#numbers.formatPercent(num)}
${#numbers.arrayFormatPercent(numArray)}
${#numbers.listFormatPercent(numList)}
${#numbers.setFormatPercent(numSet)}
% 포맷 적용
${#numbers.formatPercent(num, 3, 2)}
${#numbers.arrayFormatPercent(numArray, 3, 2)}
${#numbers.listFormatPercent(numList, 3, 2)}
${#numbers.setFormatPercent(numSet, 3, 2)}
% 포맷을 적용하되 정수와 소수의 최소 자리수 설정
${#numbers.sequence(from,to)}
${#numbers.sequence(from,to,step)}
from 부터 to 까지 연속된 index의 숫자 배열을 출력
ex) sequence(0, 5)
→{0, 1, 2, 3, 4, 5}

 

strings

종류 설명
${#strings.toString(obj)} null에 안전한 toString()
${#strings.isEmpty(name)}
${#strings.arrayIsEmpty(nameArr)}
${#strings.listIsEmpty(nameList)}
${#strings.setIsEmpty(nameSet)}
null 또는 공백인지 체크. true, false로 리턴함.
${#strings.defaultString(text, default)}
${#strings.arrayDefaultString(textArr, default)}
${#strings.listDefaultString(textList, default)}
${#strings.setDefaultString(textSet, default)}
null 또는 공백일 때 default에 입력한 값으로 변경.
ex) ${#strings.defaultString(text,'-')}
→ null이거나 공백일 경우 '-' 로 변경
${#strings.contains(name, 'ez')}
${#strings.containsIgnoreCase(name, 'ez')}
문자열에 대상 문자열이 포함되어 있는지 판단.
IgnoreCase는 대소문자를 무시함.
true, false로 리턴함.
${#strings.startsWith(name,'Don')}
${#strings.endsWith(name,'Don')}
시작 문자열 또는 끝 문자열 일치 여부 확인
true, false로 리턴함.
${#strings.indexOf(name, 'ez')}
${#strings.substring(name, 3, 5)}
${#strings.substringAfter(name, prefix)}
${#strings.substringBefore(name, suffix)}
${#strings.replace(name, 'las', 'ler')}
대상 문자열과 일치하는 문자열의 첫 인덱스 출력
문자열을 입력한 인덱스 만큼 자르기
문자열로 찾은 후 인덱스만큼 자르기
문자열 찾은 후 전 인덱스 만큼 자르기
일치하는 문자열 지정한 문자열로 대체
${#strings.prepend(str,prefix)}
${#strings.append(str,suffix)}
문자열 앞/뒤에 문자열 추가
${#strings.toUpperCase(name)}
${#strings.toLowerCase(name)}
대문자로 변경
소문자로 변경
${#strings.arrayJoin(namesArray,',')}
${#strings.listJoin(namesList,',')}
${#strings.setJoin(namesSet,',')}
${#strings.arraySplit(namesStr,',')}
${#strings.listSplit(namesStr,',')}
${#strings.setSplit(namesStr,',')}
특정문자열로 나누거나 문자열 사이에 특정 문자열 추가
${#strings.trim(str)} 문자열의 공백 제거
${#strings.length(str)} 문자열의 길이를 출력
${#strings.abbreviate(str,10)} 문자열이 설정한 길이를 초과하면 ...으로 표현
${#strings.capitalize(str)}
${#strings.unCapitalize(str)}
문자열의 첫 글자를 대문자/소문자로 변경
${#strings.capitalizeWords(str)}
${#strings.capitalizeWords(str,delimiters)}
문자열의 각 문장의 첫 글자를 대문자/소문자로 변경
${#strings.escapeXml(str)}
${#strings.escapeJava(str)}
${#strings.escapeJavaScript(str)}
${#strings.unescapeJava(str)}
${#strings.unescapeJavaScript(str)}
xml, java 등 escape/unescape
${#strings.equals(first, second)}
${#strings.equalsIgnoreCase(first, second)}
${#strings.concat(values...)}
${#strings.concatReplaceNulls(nullValue, values...)}
문자열이 일치하는지 체크
문자열이 일치하는지 대소문자를 무시하고 체크
${#strings.randomAlphanumeric(count)} characters 타입 중 랜덤한 문자열을 count 만큼 출력
0...9 and A...Z

 

arrays

종류 설명
${#arrays.toArray(object)} 오브젝트를 배열로 변환
${#arrays.toStringArray(object)}
${#arrays.toIntegerArray(object)}
${#arrays.toLongArray(object)}
${#arrays.toDoubleArray(object)}
${#arrays.toFloatArray(object)}
${#arrays.toBooleanArray(object)}
오브젝트를 각 타입으로된 배열로 변환
${#arrays.length(array)} 배열의 길이를 출력
${#arrays.isEmpty(array)} 배열이 비었는지 검사. true, false 로 리턴함.
${#arrays.contains(array, element)}
${#arrays.containsAll(array, elements)}
배열에 해당 엘리먼트가 있는지 검사. true, false 로 리턴함.

 

 

lists

종류 설명
${#lists.toList(object)} 오브젝트를 리스트로 변환
${#lists.size(list)} 리스트의 사이즈를 출력
${#lists.isEmpty(list)} 리스트가 비었는지 검사. true, false 로 리턴함.
${#lists.contains(list, element)}
${#lists.containsAll(list, elements)}
리스트에 해당 엘리먼트가 있는지 검사. true, false 로 리턴함.
${#lists.sort(list)}
${#lists.sort(list, comparator)}
리스트를 기본 정렬
리스트를 조건에 의해 정렬 ex) reverse

 

 

sets

종류 설명
${#sets.toSet(object)} 오브젝트를 셋으로 변환
${#sets.size(set)} 셋의 사이즈를 출력
${#sets.isEmpty(set)} 셋이 비었는지 검사, true, false 로 리턴함.
${#sets.contains(set, element)}
${#sets.containsAll(set, elements)}
셋에 해당 엘리먼트가 있는지 검사. true, false 로 리턴함.

 

maps

종류 설명
${#maps.size(map)} 맵의 사이즈를 출력
${#maps.isEmpty(map)} 맵이 비었는지 검사. true, false 로 리턴함.
${#maps.containsKey(map, key)}
${#maps.containsAllKeys(map, keys)}
${#maps.containsValue(map, value)}
${#maps.containsAllValues(map, value)}
맵에 해당 엘리먼트가 있는지 검사. true, false 로 리턴함.

 

 

objects

종류 설명
${#objects.nullSafe(obj,default)}
${#objects.arrayNullSafe(objArray,default)}
${#objects.listNullSafe(objList,default)}
${#objects.setNullSafe(objSet,default)}
해당 오브젝트가 null일 경우 default 값을 리턴함.
null이 아닐경우 해당 오브젝트 리턴함.

 

 

bools

종류 설명
${#bools.isTrue(obj)}
${#bools.arrayIsTrue(objArray)}
${#bools.listIsTrue(objList)}
${#bools.setIsTrue(objSet)}
입력받은 오브젝트가 true로 판단되는지 여부를 출력
collection 객체의 경우 boolean 타입의 collection으로 반환.
${#bools.isFalse(cond)}
${#bools.arrayIsFalse(condArray)}
${#bools.listIsFalse(condList)}
${#bools.setIsFalse(condSet)}
입력받은 오브젝트가 false로 판단되는지 여부를 출력
collection 객체의 경우 boolean 타입의 collection으로 반환.
${#bools.arrayAnd(condArray)}
${#bools.listAnd(condList)}
${#bools.setAnd(condSet)}
입력받은 collection 객체의 모든 오브젝트에 대해 and 조건 적용.
전부 true일 경우 true를 리턴.
${#bools.arrayOr(condArray)}
${#bools.listOr(condList)}
${#bools.setOr(condSet)}
입력받은 collection 객체의 모든 오브젝트에 대해 or조건 적용.
하나라도 true가 아닐 경우 false 리턴.

 

dates

종류 설명
${#dates.format(date)}
${#dates.arrayFormat(datesArray)}
${#dates.listFormat(datesList)}
${#dates.setFormat(datesSet)}
입력받은 값을 standard 포맷으로 변환
${#dates.formatISO(date)}
${#dates.arrayFormatISO(datesArray)}
${#dates.listFormatISO(datesList)}
${#dates.setFormatISO(datesSet)}
입력받은 값을 ISO8601 포맷으로 변환
${#dates.format(date, 'dd/MMM/yyyy HH:mm')}
${#dates.arrayFormat(datesArray, 'dd/MMM/yyyy HH:mm')}
${#dates.listFormat(datesList, 'dd/MMM/yyyy HH:mm')}
${#dates.setFormat(datesSet, 'dd/MMM/yyyy HH:mm')}
입력받은 값을 지정된 포맷으로 변환
ex) format(cal, 'dd/MM/yyyy HH:mm')
→ 21/09/2022 12:42
ex) format(cal, 'yyyy-MM-dd HH:mm:ss')
→ 2022-09-21 12:42:05
${#dates.day(date)}
${#dates.month(date)}
${#dates.monthName(date)}
${#dates.monthNameShort(date)}
${#dates.year(date)}
${#dates.dayOfWeek(date)}
${#dates.dayOfWeekName(date)}
${#dates.dayOfWeekNameShort(date)}
${#dates.hour(date)}
${#dates.minute(date)}
${#dates.second(date)}
${#dates.millisecond(date)}
dates 객체의 특정 요소값을 출력
${#dates.create(year,month,day)}
${#dates.create(y,m,d,hour,minute)}
${#dates.create(y,m,d,h,m,second)}
${#dates.create(y,m,d,h,m,s,millisecond)}
원하는 요소를 넣어서 dates 객체를 생성
${#dates.createNow()}
${#dates.createNowForTimeZone()}
현재 시간으로 dates 객체 생성
${#dates.createToday()}
${#dates.createTodayForTimeZone()}
오늘 날짜로 dates 객체 생성

 

calendars

종류 설명
${#calendars.format(cal)}
${#calendars.arrayFormat(calArray)}
${#calendars.listFormat(calList)}
${#calendars.setFormat(calSet)}
입력받은 값을 standard 포맷으로 변환
${#calendars.formatISO(cal)}
${#calendars.arrayFormatISO(calArray)}
${#calendars.listFormatISO(calList)}
${#calendars.setFormatISO(calSet)}
입력받은 값을 ISO8601 포맷으로 변환
${#calendars.format(cal, 'dd/MM/yyyy HH:mm')}
${#calendars.arrayFormat(calArray, 'dd/MM/yyyy HH:mm')}
${#calendars.listFormat(calList, 'dd/MM/yyyy HH:mm')}
${#calendars.setFormat(calSet, 'dd/MM/yyyy HH:mm')}
입력받은 값을 지정된 포맷으로 변환
ex) format(cal, 'dd/MM/yyyy HH:mm')
→ 21/09/2022 12:42
ex) format(cal, 'yyyy-MM-dd HH:mm:ss')
→ 2022-09-21 12:42:05
${#calendars.day(date)}
${#calendars.month(date)}
${#calendars.monthName(date)}
${#calendars.monthNameShort(date)}
${#calendars.year(date)}
${#calendars.dayOfWeek(date)}
${#calendars.dayOfWeekName(date)}
${#calendars.dayOfWeekNameShort(date)}
${#calendars.hour(date)}
${#calendars.minute(date)}
${#calendars.second(date)}
${#calendars.millisecond(date)}
calendars 객체의 특정 요소값을 출력
${#calendars.create(year,month,day)}
${#calendars.create(y,m,d,hour,minute)}
${#calendars.create(y,m,d,h,m,second)}
${#calendars.create(y,m,d,h,m,s,millisecond)}
${#calendars.createForTimeZone(year,month,day,timeZone)}
${#calendars.createForTimeZone(y,m,d,hour,minute,timeZone)}
${#calendars.createForTimeZone(y,m,d,h,m,second,timeZone)}
${#calendars.createForTimeZone(y,m,d,h,m,s,millisecond,timeZone)}
calendars 객체를 생성. 
원하는 요소를 넣을 수 있음.
${#calendars.createNow()}
${#calendars.createNowForTimeZone()}
현재 시간으로 calendars 객체 생성
${#calendars.createToday()}
${#calendars.createTodayForTimeZone()}
오늘 날짜로 calendars 객체 생성

uris

종류 설명
${#uris.escapePath(uri)}
${#uris.escapePath(uri, encoding)}
${#uris.unescapePath(uri)}
${#uris.unescapePath(uri, encoding)}
uri path를 escape/unescape
${#uris.escapePathSegment(uri)}
${#uris.escapePathSegment(uri, encoding)}
${#uris.unescapePathSegment(uri)}
${#uris.unescapePathSegment(uri, encoding)}
uri path segment 를 escape/unescape
${#uris.escapeFragmentId(uri)}
${#uris.escapeFragmentId(uri, encoding)}
${#uris.unescapeFragmentId(uri)}
${#uris.unescapeFragmentId(uri, encoding)}
uri path fragment를 escape/unescape
${#uris.escapeQueryParam(uri)}
${#uris.escapeQueryParam(uri, encoding)}
${#uris.unescapeQueryParam(uri)}
${#uris.unescapeQueryParam(uri, encoding)}
uri path query parameter를 escape/unescape