Spring mvc系列八之 页面静态化(一)

提升网站性能的方式有很多,例如使用缓存技术,页面静态化等.对于一个网站来说,如果数据更新频率不高的话,那就没有必要没次都要从数据库取数据,一来调动数据库,响应速度慢,二来增加服务器对数据响应的负荷,三来不利于优化引擎.随着一个网站的访问量的加大,每次从数据库读取数据是以效率为代价的,特别是一些门户网站,网站访问慢对用户体验很不好.所以页面静态化是一个不错的选择.

页面静态化适合的场景:

  1. 数据更新不高的网站,如新闻型网站
  2. 实时性不是很高的网站,当然跟静态的方式有关,如果做成没增删改都静态化一次那就没这个问题,如果做成每隔一段时间更新一次就不可以了.
  3. 数据量不是很大的网站,如果一个网站有上万条记录,每条都生成一个页面谁受得了.

页面静态化的方法很多,这次我是基于freemarker.freeMarker是一个用Java语言编写的模板引擎,它基于模板来生成文本输出。当然还有比较出名的是Velocity.在使用freeMarker前有必要先讲一下freeMarker标签的用法.

freeMarker一些内置函数:

内置函数freeMa    sequence?first 返回sequence的第一个值。

sequence?last  返回sequence的最后一个值。

sequence?reverse sequence的现有顺序反转,即倒序排序

sequence?size    返回sequence的大小

sequence?sort    sequence中的对象转化为字符串后顺序排序

sequence?sort_by(value) sequence中对象的属性value进行排序

直接获取Controller传过来的变量.

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title></title>
</head>
<body>
	${title}
</body>
</html>

 获取Controller传过来的对象.

${user.userPassword}

遍历集合:

<#list lists as user>
		用户名:${user.userName}<br/>
		密码:${user.userPassword}<br/>
		住址:${user.userInfo.address}<br/>
	</#list>

这是关于遍历集合其它一些用法,不多说.看了就懂:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title></title>
</head>
<body>
	<#list lists as user>
		用户名:${user.userName}<br/>
		密码:${user.userPassword}<br/>
		住址:${user.userInfo.address}<br/>
	</#list>
	<br/>
	list隐含变量item_index, 当前迭代项在所有迭代项中的位置<br/>
	<#list lists as user>
		第${user_index + 1}个用户<br/>
		用户名:${user.userName}<br/>
		密码:${user.userPassword}<br/>
		住址:${user.userInfo.address}<br/>
		<hr/>
	</#list>
	
	list隐含变量item_has_next, 用于判断当前迭代项是否是所有迭代项中的最后一项。<br/>
	<#list lists as user>
		用户名:${user.userName}<br/>
		密码:${user.userPassword}<br/>
		住址:${user.userInfo.address}<br/>
		<hr/>
		<#if !user_has_next>
			共有${lists?size}最后一个用户名是:${user.userName}
		</#if>
	</#list>
	
	<h4>list隐含变量sort_by有一个参数,该参数用于指定想要排序的子变量,排序是按照变量对应的值进行排序</h4><br/>
	<#list lists?sort_by("userName") as user>
		用户名:${user.userName}<br/>
		密码:${user.userPassword}<br/>
		住址:${user.userInfo.address}<br/>
		<hr/>
	</#list>
	
	
	<h4>list隐含变量reverse还可以同sort_by一起使用 </h4><br/>
	<#list lists?sort_by("userName")?reverse as user>
		用户名:${user.userName}<br/>
		密码:${user.userPassword}<br/>
		住址:${user.userInfo.address}<br/>
		<hr/>
	</#list>
</body>
</html>

 获取Map数据:

Hash的内置函数
    hash?keys 返回hash里的所有key,返回结果为sequence
    hash?values 返回hash里的所有value,返回结果为sequence

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title></title>
</head>
<body>
	<#list maps?keys as testKey>
		键${testKey} 值${maps[testKey].userName}
	</#list>
</body>
</html>

直接获取Map的值:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title></title>
</head>
<body>
	<#list maps?values as value>
		值${value} 
	</#list>
</body>
</html>

 讲了freemarker后下一篇就讲一讲如何使用freemarker结合spring mvc实现页面静态化.

提升网站性能的方式有很多,例如使用缓存技术,页面静态化等.对于一个网站来说,如果数据更新频率不高的话,那就没有必要没次都要从数据库取数据,一来调动数据库,响应速度慢,二来增加服务器对数据响应的负荷,三来不利于优化引擎.随着一个网站的访问量的加大,每次从数据库读取数据是以效率为代价的,特别是一些门户网站,网站访问慢对用户体验很不好.所以页面静态化是一个不错的选择. 页面静态化适合的场景:
  1. 数据更新不高的网站,如新闻型网站
  2. 实时性不是很高的网站,当然跟静态的方式有关,如果做成没增删改都静态化一次那就没这个问题,如果做成每隔一段时间更新一次就不可以了.
  3. 数据量不是很大的网站,如果一个网站有上万条记录,每条都生成一个页面谁受得了.

猜你喜欢

转载自mylfd.iteye.com/blog/1894407