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