【springboot】web视图
创始人
2025-05-29 05:12:22
0

5、视图解析与模板引擎

视图解析:SpringBoot默认不支持 JSP,需要引入第三方模板引擎技术实现页面渲染。

1、视图解析

img

1、视图解析原理流程

1、目标方法处理的过程中,所有数据都会被放在 ModelAndViewContainer 里面。包括数据和视图地址

2、方法的参数是一个自定义类型对象(从请求参数中确定的),把他重新放在 ModelAndViewContainer

3、任何目标方法执行完成以后都会返回 ModelAndView(数据和视图地址)。

**4、**processDispatchResult 处理派发结果(页面改如何响应)

  • 1、render(mv, request, response); 进行页面渲染逻辑

    • 1、根据方法的String返回值得到 View 对象【定义了页面的渲染逻辑】
      • 1、所有的视图解析器尝试是否能根据当前返回值得到View对象
      • 2、得到了 redirect:/main.html --> Thymeleaf new RedirectView()
      • 3、ContentNegotiationViewResolver 里面包含了下面所有的视图解析器,内部还是利用下面所有视图解析器得到视图对象。
      • 4、view.render(mv.getModelInternal(), request, response); 视图对象调用自定义的render进行页面渲染工作
        • RedirectView 如何渲染【重定向到一个页面】
        • 1、获取目标url地址
        • **2、**response.sendRedirect(encodedURL);

视图解析:

    • 返回值以 forward: 开始: new InternalResourceView(forwardUrl); --> 转发****request.getRequestDispatcher(path).forward(request, response);
    • 返回值以 redirect: 开始: new RedirectView() --》 render就是重定向
    • 返回值是普通字符串: new ThymeleafView()—>

自定义视图解析器+自定义视图; 大厂学院。

img

img

img

img

2、模板引擎-Thymeleaf

1、thymeleaf简介

Thymeleaf is a modern server-side Java template engine for both web and standalone environments, capable of processing HTML, XML, JavaScript, CSS and even plain text.

现代化、服务端Java模板引擎

2、基本语法

1、表达式

表达式名字语法用途
变量取值${...}获取请求域、session域、对象等值
选择变量*{...}获取上下文对象值
消息#{…}获取国际化等值
链接@{…}生成链接
片段表达式~{…}jsp:include 作用,引入公共页面片段

2、字面量

文本值: ‘one text’ , ‘Another one!’ **,…**数字: 0 , 34 , 3.0 , 12.3 **,…**布尔值: true , false

空值: null

变量: one,two,… 变量不能有空格

3、文本操作

字符串拼接: +

变量替换: |The name is ${name}|

4、数学运算

运算符: + , - , * , / , %

5、布尔运算

运算符: and , or

一元运算: ! , not

6、比较运算

比较: > , < , >= , <= ( gt , lt , ge , le **)**等式: == , != ( eq , ne )

7、条件运算

If-then: (if) ? (then)

If-then-else: (if) ? (then) : (else)

Default: (value) ?: (defaultvalue)

8、特殊操作

无操作: _

3、设置属性值-th:attr

设置单个值

设置多个值


以上两个的代替写法 th:xxxx


所有h5兼容的标签写法

https://www.thymeleaf.org/doc/tutorials/3.0/usingthymeleaf.html#setting-value-to-specific-attributes

4、迭代

Onions2.41yes

Onions2.41yes

5、条件运算

view

User is an administrator

User is a manager

User is some other thing

6、属性优先级

img

3、thymeleaf使用

1、引入Starter

        org.springframework.bootspring-boot-starter-thymeleaf

2、自动配置好了thymeleaf

@Configuration(proxyBeanMethods = false)
@EnableConfigurationProperties(ThymeleafProperties.class)
@ConditionalOnClass({ TemplateMode.class, SpringTemplateEngine.class })
@AutoConfigureAfter({ WebMvcAutoConfiguration.class, WebFluxAutoConfiguration.class })
public class ThymeleafAutoConfiguration { }

自动配好的策略

  • 1、所有thymeleaf的配置值都在 ThymeleafProperties
  • 2、配置好了 SpringTemplateEngine
  • 3、配好了 ThymeleafViewResolver
  • 4、我们只需要直接开发页面
	public static final String DEFAULT_PREFIX = "classpath:/templates/";public static final String DEFAULT_SUFFIX = ".html";  //xxx.html

3、页面开发



Title


哈哈

去百度
去百度2

4、构建后台管理系统

1、项目创建

thymeleaf、web-starter、devtools、lombok

2、静态资源处理

自动配置好,我们只需要把所有静态资源放到 static 文件夹下

3、路径构建

th:action=“@{/login}”

4、模板抽取

th:insert/replace/include

5、页面跳转

    @PostMapping("/login")public String main(User user, HttpSession session, Model model){if(StringUtils.hasLength(user.getUserName()) && "123456".equals(user.getPassword())){//把登陆成功的用户保存起来session.setAttribute("loginUser",user);//登录成功重定向到main.html;  重定向防止表单重复提交return "redirect:/main.html";}else {model.addAttribute("msg","账号密码错误");//回到登录页面return "login";}}

6、数据渲染

    @GetMapping("/dynamic_table")public String dynamic_table(Model model){//表格内容的遍历List users = Arrays.asList(new User("zhangsan", "123456"),new User("lisi", "123444"),new User("haha", "aaaaa"),new User("hehe ", "aaddd"));model.addAttribute("users",users);return "table/dynamic_table";}
#用户名密码
TridentInternet[[${user.password}]]

相关内容

热门资讯

在岸人民币兑美元收盘大跌479... 11月12日消息,在岸人民币兑美元收盘大跌479点至7.2378元,创8月1日以来新低。
香港将促进大湾区内的跨境低空飞... 11月12日消息,香港新一份施政报告宣布成立“发展低空经济工作组”,香港特区政府财政司副司长黄伟纶今...
上交所就世茂能源筹划发行股份购... 11月12日消息,今日,上交所就世茂能源筹划发行股份购买资产事项下发监管工作函,涉及对象为上市公司、...
重庆前10月重点项目投资超40... 11月12日消息,重庆市发改委最新统计数据显示,1—10月,市级重点建设项目已完成投资4003亿元,...
李子柒时隔3年公开更新视频 11月12日消息,2024年11月12日,李子柒时隔3年在社交平台公开更新视频,表示“很想你们”。文...
2025北京会议策划公司推荐|... 2025北京会议策划公司推荐|政企+商务+北京飞鸟创意首选! 在北京这座汇聚了国家部委、世界500强...
方洪波:“生成式”美的未来 方洪波有其理想主义的一面,但更是一位极其务实的改革者。文|《中国企业家》记者 梁宵编辑|米娜头图摄影...
优迅股份登陆科创板 国产光通信... 中经记者 谭伦 北京报道12月19日,厦门优迅芯片股份有限公司(688807.SH,以下简称“优迅股...
一年消失三百多家,中小银行遭遇... 放在以前,银行的工作,可都被大家称之为“铁饭碗”,毕竟只要有人花钱,银行这“存钱”跟“借钱”的生意基...
ALL IN中国供应链,拼多多... *此图由AI生成作者| 史大郎&猫哥来源| 是史大郎&大猫财经Pro“3年时间Temu走了拼多多差不...