一个模板,从数据库取n条记录,生成静态。
做单页面的静态化,索引页面是用JS对数组进行组合的。
因为记录只是一个标题,一个链接,字节数不会太大,
那么用js去用这个大数组进行分页,貌似不错,很节约带宽!
还是很棒的,简单,实用,值得推荐!
JS代码:
function
title_array(title, link_add, store_time) {
this
.title = title;
this
.link_add = link_add;
this
.store_time = store_time;
}
var
ii = 0;
var
item =
new
Array();
ii++; item[ii] =
new
title_array(
'学无止境 25'
,
'#'
,
'(03月17日 23:47)'
);
ii++; item[ii] =
new
title_array(
'学无止境 24'
,
'#'
,
'(03月17日 23:42)'
);
ii++; item[ii] =
new
title_array(
'学无止境 23'
,
'#'
,
'(03月17日 23:32)'
);
ii++; item[ii] =
new
title_array(
'学无止境 22'
,
'#'
,
'(03月17日 23:29)'
);
ii++; item[ii] =
new
title_array(
'学无止境 21'
,
'#'
,
'(03月17日 23:19)'
);
ii++; item[ii] =
new
title_array(
'学无止境 20'
,
'#'
,
'(03月17日 23:15)'
);
ii++; item[ii] =
new
title_array(
'学无止境 19'
,
'#'
,
'(03月17日 23:13)'
);
ii++; item[ii] =
new
title_array(
'学无止境 18'
,
'#'
,
'(03月17日 23:12)'
);
ii++; item[ii] =
new
title_array(
'学无止境 17'
,
'#'
,
'(03月17日 23:10)'
);
ii++; item[ii] =
new
title_array(
'学无止境 16'
,
'#'
,
'(03月17日 22:35)'
);
ii++; item[ii] =
new
title_array(
'学无止境 15'
,
'#'
,
'(03月17日 22:29)'
);
ii++; item[ii] =
new
title_array(
'学无止境 14'
,
'#'
,
'(03月17日 22:28)'
);
ii++; item[ii] =
new
title_array(
'学无止境 13'
,
'#'
,
'(03月17日 22:27)'
);
ii++; item[ii] =
new
title_array(
'学无止境 12'
,
'#'
,
'(03月17日 22:26)'
);
ii++; item[ii] =
new
title_array(
'学无止境 11'
,
'#'
,
'(03月17日 22:24)'
);
ii++; item[ii] =
new
title_array(
'学无止境 10'
,
'#'
,
'(03月17日 22:23)'
);
ii++; item[ii] =
new
title_array(
'学无止境 9'
,
'#'
,
'(03月17日 22:02)'
);
ii++; item[ii] =
new
title_array(
'学无止境 8'
,
'#'
,
'(03月17日 22:02)'
);
ii++; item[ii] =
new
title_array(
'学无止境 7'
,
'#'
,
'(03月17日 22:01)'
);
ii++; item[ii] =
new
title_array(
'学无止境 6'
,
'#'
,
'(03月17日 21:51)'
);
ii++; item[ii] =
new
title_array(
'学无止境 5'
,
'#'
,
'(03月17日 21:51)'
);
ii++; item[ii] =
new
title_array(
'学无止境 4'
,
'#'
,
'(03月17日 21:50)'
);
ii++; item[ii] =
new
title_array(
'学无止境 3'
,
'#'
,
'(03月17日 21:31)'
);
ii++; item[ii] =
new
title_array(
'学无止境 2'
,
'#'
,
'(03月17日 21:30)'
);
ii++; item[ii] =
new
title_array(
'学无止境 1'
,
'#'
,
'(03月17日 21:30)'
);
//要显示的页面
var
currpage = 1;
//一页显示信息条数为40
var
pagesize = 5;
//页数维护所显示的第一页
var
beginpage = 1;
//页数维护所显示的最后一页
var
endpage = 100;
//显示某一页的内容
function
displaypage(onepage) {
if
(onepage < 1) {
alert(
"已到达首页"
);
return
;
}
var
NumRecords;
if
(item.length == 1) {
NumRecords = item.length;
}
else
{
NumRecords = item.length - 1;
//信息总条数,减一因为是从下标[1]开始存的信息。
}
//没有信息就返回
if
(NumRecords <= 0) {
return
false
;
}
NumPages = Math.floor((NumRecords + (pagesize - 1)) / pagesize);
//总页数
if
(onepage > NumPages) {
alert(
"已经到达尾页"
);
return
;
}
currpage = onepage;
//该页的第一行
var
start = pagesize * (currpage - 1) + 1;
if
(NumRecords == 1) {
start = start - 1;
}
if
(start >= item.length)
return
;
//装入该页内容
var
strText =
""
;
for
(
var
i = 1; i <= pagesize / 5; i++) {
strText +=
"<div class=\"title_list\"><ul class=\"title_list bluepoint\">"
for
(
var
j = 1; j <= 5; j++) {
if
(start < item.length) {
strText +=
"<li><a href=\""
+ item[start].link_add +
"\" target=\"_blank\">"
+ item[start].title +
"</a><span>"
+ item[start].store_time +
"</span></li>"
;
start++;
}
}
strText +=
"</ul></div>"
}
document.getElementById(
"title1"
).innerHTML = strText;
//如果总页数不足5条
if
(NumPages < 10) {
beginpage = 1;
endpage = NumPages;
}
else
{
//如果显示最前面的5页
if
(currpage <= 5 && currpage > 0) {
beginpage = 1;
endpage = 10;
}
//如果显示最后面的5页
if
(currpage <= NumPages && currpage > (NumPages - 9)) {
beginpage = NumPages - 9;
endpage = NumPages;
}
//其他情况
if
(currpage > 5 && currpage < (NumPages - 9)) {
if
(currpage >= (endpage + 1)) {
beginpage += 10;
endpage += 10;
}
if
(currpage <= (beginpage - 1)) {
beginpage -= 10;
endpage -= 10;
}
}
}
var
showtext =
""
;
if
(NumPages > 0) {
showtext +=
"<span class=\"tpb_right\"><a href=\"javascript:displaypage(1)\" class=\"tpb_btn_previous\"><<</a> "
;
showtext +=
"<a href=\"javascript:displaypage(currpage-1)\">上一页</a> "
;
var
currpages = currpage < NumPages - 2 ? currpage + 2 : NumPages;
var
currpage1 = currpage <= 2 ? 1 : currpage - 2;
if
(NumPages <= 10) {
currpage1 = 1;
currpages = NumPages;
}
else
if
(currpage1 >= 2) {
showtext +=
"<a href=\"javascript:displaypage(1)\">1</a> "
;
if
(currpage1 > 2) {
showtext +=
"..."
;
}
}
for
(i = currpage1; i <= currpages; i++) {
if
(currpage == (i)) {
showtext +=
"<a class=\"cur\" href=\"javascript:displaypage("
+ i +
")\">"
+ i +
"</a> "
;
}
else
{
showtext +=
"<a href=\"javascript:displaypage("
+ i +
")\">"
+ i +
"</a> "
;
}
}
if
(NumPages > 10 && currpages <= NumPages - 1) {
if
(currpages < NumPages - 1) {
showtext +=
"..."
;
}
showtext +=
"<a href=\"javascript:displaypage("
+ NumPages +
")\">"
+ NumPages +
"</a> "
;
}
showtext = showtext +
"<a href=\"javascript:displaypage(currpage+1)\">下一页 </a>"
;
showtext = showtext +
"<a href=\"javascript:displaypage(NumPages)\">>></a></span>"
;
}
document.getElementById(
"page1"
).innerHTML = showtext;
}
|
调用:
<DIV id=title1> </DIV>
<DIV id=page1
class
=turn_page_box> </DIV>
<SCRIPT language=javascript>
//默认显示首页的内容
displaypage(1);
</SCRIPT>
|