zoukankan      html  css  js  c++  java
  • 【SpringBoot】Web开发

    一、简介

    1.1 引入SpringBoot模块

      在介绍Web开发模块之前,先总结一下SpringBoot中如何引入某一个模块,我们知道,SpringBoot将功能模块封装为一个个的Starter

    • 1)、创建SpringBoot应用,选中我们需要的模块;
    • 2)、SpringBoot已经默认将这些场景配置好了,只需要在配置文件中指定少量配置就可以运行起来
    • 3)、自己编写业务代码;

    • 这个场景SpringBoot帮我们配置了什么?能不能修改?能修改哪些配置?能不能扩展?

    1. xxxxAutoConfiguration:帮我们给容器中自动配置组件;
    2. xxxxProperties:配置类来封装配置文件的内容;

    1.2 SpringBoot对静态资源的映射规则

    • 1)、所有 /webjars/** ,都去资源jar包下 classpath:/META-INF/resources/webjars/ 找资源;
      • webjars:以jar包的方式引入静态资源;

    webjars网站,进入网站,如下:

    <!‐‐引入jquery‐webjar 在访问的时候只需要写webjars下面资源的名称即可 ‐‐>
    <dependency>
        <groupId>org.webjars</groupId>
        <artifactId>jquery</artifactId>
        <version>3.4.1</version>
    </dependency>
    

    示例
    如果引用jquery,那么路径应该写为:

    localhost:8080/webjars/jquery/3.4.1/jquery.js
    
    • 2)、"/**" 访问当前项目的任何资源,都去(静态资源的文件夹)找映射
    "classpath:/META‐INF/resources/", 
    "classpath:/resources/",
    "classpath:/static/",
    "classpath:/public/"
    "/":当前项目的根路径
    

    示例

    localhost:8080/abc # 去静态资源文件夹里面找abc
    
    • 3)、欢迎页; 静态资源文件夹下的所有index.html页面;被"/**"映射;

    示例: localhost:8080/ 找index页面

    • 4)、所有的 **/favicon.ico 都是在静态资源文件下找;

    二、模版引擎

    2.1 简介

    • 我们常见的模版引擎有:JSP、Velocity、Freemarker、Thymeleaf
    • SpringBoot官网推荐我们用Thymeleaf

    原理图如下:

    2.2 引入thymeleaf

    
    <properties>
         <!-- 修改版本 -->
            <thymeleaf.version>3.0.9.RELEASE</thymeleaf.version>
            <!-- 布局功能的支持程序 thymeleaf3主程序 layout2以上版本 -->
            <!-- thymeleaf2 layout1 -->
            <thymeleaf-layout-dialect.version>2.2.2</thymeleaf-layout-dialect.version>
        </properties>
    
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    

    2.3 Thymeleaf使用

    ThymeleafProperties 类中我们可以看出Thymeleaf 如何使用以及配置信息:

    @ConfigurationProperties(prefix = "spring.thymeleaf")
    public class ThymeleafProperties {
    
        private static final Charset DEFAULT_ENCODING = StandardCharsets.UTF_8;
    
        public static final String DEFAULT_PREFIX = "classpath:/templates/";
    
        public static final String DEFAULT_SUFFIX = ".html";
        // ....省略...
    }
    
    • 只要我们把HTML页面放在classpath:/templates/,thymeleaf就能自动渲染;

    • 1、导入thymeleaf的名称空间

    <htmllang="en"xmlns:th="http://www.thymeleaf.org">
    
    • 2、使用thymeleaf语法;

    【后续整理】

  • 相关阅读:
    写了个日常开发常用的对话框(模拟alert,confirm....)
    javascrit事件绑定,删除方法(解决IE现代事件绑定方法的一些缺陷).
    常见的焦点图旋转效果
    js性能优化的一些常识
    配合鼠标滚轮事件的可自定义样式的区域滚动条插件(基于jquery)
    基于Jquery的放大镜(模仿淘宝的不同尺寸图片查看)
    华为与H3C(华三)的前世今生
    竞品分析
    postman 学习记录
    单元化架构
  • 原文地址:https://www.cnblogs.com/haoworld/p/springbootweb-kai-fa.html
Copyright © 2011-2022 走看看