thymeleaf在工作中遇到的问题及解决办法(四)

Easter79
• 阅读 757

1、关于字符串拼接的问题

        字符串拼接可以使用如下方式。

<a href="#" th:text="第+${StartNo}+页 +'    '+共+${countPage}+页">

        还有一种更优雅的方式,使用“||”减少了字符串的拼接,代码如下。

<a href="#" th:text="|第${StartNo}页     共${countPage}页|">

2、关于URL表达式中传参的问题

        这个问题也比较常遇到,比如想通过超链接删除数据库中某条数据,那么在超链接上就需要传入此数据的主键。如图,我要修改此用户那么就要在修改的超链接上把10064这个ID传进来。

thymeleaf在工作中遇到的问题及解决办法(四)

thymeleaf在工作中遇到的问题及解决办法(四)

超链接传参代码如下,需要注意Thymeleaf对URL进行渲染,务必使用th:href,th:src属性 。

<a class="border-main" th:href="@{userPower(id=${user.Id})}"><span class="edit"></span> 修改

几点需要说明:

  • 上例URL最后的(id=${user.Id})表示将括号内的内容作为URL参数处理,该语法避免使用字符串拼接,大大提高了可读性。
  • @{userPower}是Context相关的相对路径,在渲染时会自动添加上当前Web应用的Context名字,假设Context名字为Java,那么结果应该是/Java/userPower。

3、关于条件判断的补充

      前面介绍了if的用法,接下来介绍一个与if用法相同但表达相反的属性 th:unless ,两者都是条件判断,if表示表达式成立则执行动作,而unless表示表达式中的条件不成立,才会执行动作。

      thymeleaf还有一种类似Java中的三元运算符的用法,代码如下。

<input th:text="(${user.isAdmin}?'管理员':'普通用户')"></input>

4、关于特殊字符的转义

  • 比较: > , < , >= , <= ( gt , lt , ge , le )
  • 相等算法: == , != ( eq , ne )

5、关于一些其他的常用内置对象

Controller代码:

@RestController
public class IndexController {

    @PostMapping("toIndex")
    public String toIndex(Model model) {
        List<String> datas = new ArrayList<String>();
        datas.add("二十岁以后");
        datas.add("995600491");
        model.addAttribute("datas", datas);
        model.addAttribute("curDate", new Date());
        model.addAttribute("number", Math.random()*100);
        return "index";
    }
}

上面的代码,包含了工作中常使用的数据类型,有集合,时间类型,数值类型,下面我们使用thymeleaf的内置对象来解析他们。

  • 使用#lists.size来获取List的长度。

  • 对于日期的格式化,与java中的SimpleDateFormat类似,第一个参数是后台传来的key,第二个参数是设置日期的格式

  • 对于数值,我们可以对其这样操作。

   解释:保留三位小数, 整数位自动。

<span th:text="${#numbers.formatDecimal(number,3,1)}"></span>

  解释: 保留1位小数位,3位整数位(不够的前面加0) 。

特别提示:

内置对象前都需要加#号。

内置对象一般都以s结尾。

其他常用内置对象:

#numbers: 数字格式化;

#strings:字符串格式化,参照java.lang.String;

#bools:判断boolean类型;

#lists:集合操作的工具,参照java.util.List;

#sets:Set集合操作工具,参照java.util.Set;

#maps:Map集合操作工具,参照java.util.Map; 

#dates:日期格式化,参照java.util.Date;
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Karen110 Karen110
3年前
一篇文章带你了解JavaScript日期
日期对象允许您使用日期(年、月、日、小时、分钟、秒和毫秒)。一、JavaScript的日期格式一个JavaScript日期可以写为一个字符串:ThuFeb02201909:59:51GMT0800(中国标准时间)或者是一个数字:1486000791164写数字的日期,指定的毫秒数自1970年1月1日00:00:00到现在。1\.显示日期使用
Wesley13 Wesley13
3年前
java将前端的json数组字符串转换为列表
记录下在前端通过ajax提交了一个json数组的字符串,在后端如何转换为列表。前端数据转化与请求varcontracts{id:'1',name:'yanggb合同1'},{id:'2',name:'yanggb合同2'},{id:'3',name:'yang
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
JS 苹果手机日期显示NaN问题
问题描述newDate("2019122910:30:00")在IOS下显示为NaN原因分析带的日期IOS下存在兼容问题解决方法字符串替换letdateStr"2019122910:30:00";datedateStr.repl
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
LeeFJ LeeFJ
1年前
Foxnic-SQL (13) —— 外部SQL与SQL模版
首先,大多数时候,我们的第一反应是用字符串去拼接SQL语句,这说明字符串拼接方式其实是最直观的。其次,使用对象化的方式拼接SQL,还是有其局限性,大量的SQL文本也不宜直接写在Java类中。所以,FoxnicSQL将原本要写在Java类中的SQL语句放到一个外部文件中,每个语句用一个ID去标识,在SQL执行时,只要指定ID就可以了。在此基础上,FoxnicSQL加入了模板引擎、SQL语句置换、热加载等特性,使其变得更加好用。
达里尔 达里尔
10个月前
给数组添加新数据,判断数据是否重复
多选要进行数组拼接,希望判断往原数组里添的新数据是否重复,封装个简易方法languageconstdataArrayname:'aaa',id:1,name:'bbb',id:2;constnewDataname:'ccc',id:2;//要添加的新数
Easter79
Easter79
Lv1
今生可爱与温柔,每一样都不能少。
文章
2.8k
粉丝
5
获赞
1.2k