SpringMVC+Thymeleaf +HTML的简单框架
一、问题
项目中需要公众号开发,移动端使用的是H5,但是如果不用前端框架的话,只能考虑JS前端用ajax解析JSON字符串了。今天我们就简单的说下前端框架Thymeleaf如何解决这个问题的;
二、开始实战
2.1:配置pom.xml
<!-- https://mvnrepository.com/artifact/org.thymeleaf/thymeleaf-spring4 -->
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring4</artifactId>
<version>3.0..RELEASE</version>
</dependency> <!-- https://mvnrepository.com/artifact/org.thymeleaf/thymeleaf -->
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf</artifactId>
<version>3.0..RELEASE</version>
</dependency>
2.2:配置Spring mvc的主配置文件(spring-mvc.xml)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
<!-- 注解扫描包 -->
<context:component-scan base-package="com.king.weixin"/>
<!-- 开启注解 -->
<mvc:annotation-driven/>
<!--
配置静态资源,直接映射到对应的文件夹,不被DispatcherServlet处理,.04新增功能,需要重新设置spring-mvc-3.0.xsd
-->
<mvc:resources mapping="/img/**" location="/img/" />
<mvc:resources mapping="/js/**" location="/js/" />
<mvc:resources mapping="/css/**" location="/css/" />
<mvc:resources mapping="/html/**" location="/html/" />
<mvc:resources mapping="/tinymce/**" location="/tinymce/" />
<mvc:resources mapping="/upload/**" location="/upload/" />
<mvc:resources mapping="/assset/**" location="/assset/" />
<!-- 定义跳转的文件的前后缀 ,视图模式配置-->
<!--采用前端模板工具thymeleaf-->
<bean id="templateResolver" class="org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver">
<property name="prefix" value="/html/" />
<property name="suffix" value=".html" />
<property name="templateMode" value="HTML5" />
<property name="cacheable" value="false" />
<property name="characterEncoding" value="UTF-8"/>
</bean> <bean id="templateEngine"
class="org.thymeleaf.spring4.SpringTemplateEngine">
<property name="templateResolver" ref="templateResolver" /> </bean> <bean class="org.thymeleaf.spring4.view.ThymeleafViewResolver">
<property name="templateEngine" ref="templateEngine" />
<property name="characterEncoding" value="UTF-8"/>
</bean>
<!--采用前端模板工具thymeleaf-->
<!-- redis配置 -->
<import resource="spring-redis.xml"/>
</beans>
需要注意的是:下面的是关键配置
<mvc:resources mapping="/img/**" location="/img/" />
	<mvc:resources mapping="/js/**" location="/js/" />
	<mvc:resources mapping="/css/**" location="/css/" />
	<mvc:resources mapping="/html/**" location="/html/" />
	<mvc:resources mapping="/tinymce/**" location="/tinymce/" />
	<mvc:resources mapping="/upload/**" location="/upload/" />
	<mvc:resources mapping="/assset/**" location="/assset/" />
	<!-- 定义跳转的文件的前后缀 ,视图模式配置-->
    <!--采用前端模板工具thymeleaf-->
    <bean id="templateResolver" class="org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver">
        <property name="prefix" value="/html/" />
        <property name="suffix" value=".html" />
        <property name="templateMode" value="HTML5" />
        <property name="cacheable" value="false" />
        <property name="characterEncoding" value="UTF-8"/>
    </bean>
2.3:Controller配置
@RequestMapping(value = "/QueryUserbyOpenId", method = RequestMethod.GET)
public String QueryUserbyOpenId(String openid,HttpServletRequest res,ModelMap model)
{
System.out.println("来了");
User user=new User();
user=userService.findByOpenId(openid);
if(user!=null)
{
model.addAttribute("user_name", user.getUser_name());
model.addAttribute("user_sex",user.getUser_sex());
model.addAttribute("user_age", user.getUser_age());
model.addAttribute("user_address", user.getUser_address());
model.addAttribute("user_mobile", user.getUser_mobile());
}
System.out.println("------------------:"+user.getUser_id());
return "userInfo";
return 返回的就是html视图的名称,具体是html还是jsp是在spring mvc中配置,需要在方法中生命ModelMap 来存放对象
2.4:HTML取值
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<meta name="viewport" content="width=device-width, initial-scale=1" />
<meta charset="UTF-8">
<title>个人中心</title>
<!-- <link rel="stylesheet" th:href="@{/css/userInfo.css}"> -->
<link rel="stylesheet" href="../css/userInfo.css">
<script type="text/javascript" src="../js/jquery-3.3.1.min.js"></script>
</head>
<body>
<div class="home">
<div class="doctor">
<div class="doctorName" th:text="${user_name}"></div>
<img class="doctorImg" src="../assset/icon/mydoctor_man.png">
<div class="changeUserInfo" onclick="window.location.href='updateUserInfoHTML'"><img src="../assset/icon/icon_bianjiziliao@2x.png">修改个人信息</div>
<div class="count">
<div>
<span class="moneyCount">20元</span>
<span>金额</span>
</div>
<div class="borderLeft"></div>
<div>
<span class="Upoint">0个</span>
<span>U点</span>
</div>
<div class="borderRight"></div>
<div>
<span class="discount">0张</span>
<span>优惠券</span>
</div>
</div>
</div>
<div class="msg">
<div>| 基本信息</div>
<div class="msgDiv">
<span style="color: rgba(204,204,204,1)" >性别:</span><span th:text="${user_sex}"></span>
</div>
<div class="msgDiv">
<span style="color: rgba(204,204,204,1)">年龄:</span><span th:text=" ${user_age}"></span>
</div>
<div class="msgDiv">
<span style="color: rgba(204,204,204,1)">地址:</span><span th:text="${user_address}"></span>
</div>
<div class="msgDiv">
<span style="color: rgba(204,204,204,1)">手机:</span><span th:text="${user_mobile}"></span>
</div>
<!-- <div class="msgDiv"> -->
<!-- <span style="color: rgba(204,204,204,1)">个人签名:</span><span th:text="${mobile}">无就是我</span> -->
<!-- </div> -->
<!-- <div class="msgDiv"> -->
<!-- <span style="color: rgba(204,204,204,1)">手机号:</span><span th:text="${mobile}"></span> -->
<!-- </div> --> <!-- <div class="changePhoneNum" onclick="window.location.href='updateUserMobileHTML'">修改手机号</div> -->
</div>
<!-- <div class="goToDownload" onclick="javascript:test()">马上下载APP,体验更多服务</div> -->
</div>
</body>
<script type="text/javascript">
function test(){
window.location.href="download"
}
</script>
</html>
导入命名空间 <html lang="en" xmlns:th="http://www.thymeleaf.org">,用th:text标签取值
SpringMVC+Thymeleaf +HTML的简单框架的更多相关文章
- SpringMVC+Thymeleaf  简单使用
		
一.简介 1.Thymeleaf 在有网络和无网络的环境下皆可运行,而且完全不需启动WEB应用,即它可以让美工在浏览器查看页面的静态效果,也可以让程序员在服务器查看带数据的动态页面效果.浏览器解释 h ...
 - 第6章—渲染web视图—SpringMVC+Thymeleaf 处理表单提交
		
SpringMVC+Thymeleaf 处理表单提交 thymleaf处理表单提交的方式和jsp有些类似,也有点不同之处,这里操作一个小Demo,并说明: 1.demo的结构图如下所示: pom.xm ...
 - 基于SpringMVC下的Rest服务框架搭建【1、集成Swagger】
		
基于SpringMVC下的Rest服务框架搭建[1.集成Swagger] 1.需求背景 SpringMVC本身就可以开发出基于rest风格的服务,通过简单的配置,即可快速开发出一个可供客户端调用的re ...
 - NHIBERNATE的简单框架的设计
		
NHIBERNATE的简单框架的设计 上次的 NHibernate的Session管理策略和NHibernateHelper 发布并提供下载,给NHibernate刚入门的同学们带来很多便利. 最近有 ...
 - SpringMvc+thymeleaf+HTML5中文乱码问题
		
SpringMvc+thymeleaf+HTML5环境下遇到中文乱码...... 按照以往经验逐个排查,开发环境统一为utf-8编码,服务器也配置了编码过滤器,tomcat也是utf-8编码.前台页面 ...
 - springmvc拦截器的简单了解
		
1.定义一个拦截器 2.在springmvc.xml中配置拦截器. (1)拦截器拦截的请求是建立在前端控制器配置之下的,若DispatcherServlet拦截的是*.action,则拦截器即使配置 ...
 - 使用IntelliJ IDEA开发SpringMVC网站(二)框架配置
		
原文:使用IntelliJ IDEA开发SpringMVC网站(二)框架配置 摘要 讲解如何配置SpringMVC框架xml,以及如何在Tomcat中运行 目录[-] 文章已针对IDEA 15做了一定 ...
 - 基于全注解的SpringMVC+Spring4.2+hibernate4.3框架搭建
		
概述 从0到1教你搭建spring+springMVC+hibernate整合框架,基于注解. 本教程框架为基于全注解的SpringMVC+Spring4.2+hibernate4.3,开发工具为my ...
 - spring的了解以及简单框架的搭建
		
了解spring: Spring是一个开源的控制反转(Inversion of Controller)和面向切面(AOP)的框架,目的是为了简化开发. IOC(控制反转): public class ...
 
随机推荐
- mysql 5.6 在线 DDL
			
原文链接地址:http://seanlook.com/2016/05/24/mysql-online-ddl-concept/ 做MySQL的都知道,数据库操作里面,DDL操作(比如CREATE,DR ...
 - CCF2014032窗口(C语言)
			
问题描述 在某图形操作系统中,有 N 个窗口,每个窗口都是一个两边与坐标轴分别平行的矩形区域.窗口的边界上的点也属于该窗口.窗口之间有层次的区别,在多于一个窗口重叠的区域里,只会显示位于顶层的窗口里的 ...
 - 关系操作符 < >  =  ==  <=  >=  !=
			
基本类型可以用所有的操作符 对象要用equal eqauls() //用法 System.out.println(v1.equals(v2)); JAVA学习(二) STRING使用EQUALS方法和 ...
 - hdu3255扫描线:带权面积交转体积交
			
手贱把i打成j,调了半天 /* 面积并转体积并,长方体高度为作物价格 算体积并:在笛卡尔坐标系的y轴上建立线段树cnt记录区间被完全覆盖的次数,sum记录区间被覆盖的总长度 以平行于xoy的平面从下往 ...
 - Ubuntu 8.04嵌入式交叉编译环境arm-linux-gcc搭建过程图解
			
Linux版本:Ubuntu8.04 内核版本:Linux 2.6.24 交叉编译器版本:arm-linux-gcc-3.4.1 交叉编译器下载链接: https://share.weiyun.com ...
 - zend studio调试
			
XDdebug搞了我一天 先把php.ini的代码发一下 [XDebug] zend_extension = "d:/WAMP/wamp/bin/php/php5.5.12/zend_ext ...
 - A. 【UNR #1】争夺圣杯
			
题解: 一道比较水的题目 按照最一般的思路离散化后枚举最大值 然后考虑最大值的贡献 会发现需要分类讨论一下 发现对一段k的影响是等差数列 所以可以用线段树维护差分数组
 - jQuery如何退出each循环 和如何退出function函数
			
1.在函数内部使用return false是跳出function; 2.在each的回调函数中使用return false,是跳出each循环;return true 进入下一个循环: 3.break ...
 - FastAdmin 在 Nginx 中的配置
			
FastAdmin 使用的是 ThinkPHP 5 框架. 在 Apache 下很简单,但是在 nginx 下就需要自行配置一下了. 在网上找了很多,都没有找到很好的. 刚刚在 QQ 里群里找到一个, ...
 - Java开发人员必须掌握的Linux命令(二)
			
子曰:"工欲善其事,必先利其器." 学习应该是快乐的,在这个乐园中我努力让自己能用简洁易懂(搞笑有趣)的表达来讲解让知识或者技术,让学习之旅充满乐趣,这就是写博文的初心. 本篇的旅 ...