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