对一篇很长的文章做到完美的分页输出

利用统计文章字数,然后达到一定字数就截断输出,但是分页的内容就会在莫名其妙的地方截断,不是很友好。
很简单,在要截断的地方附近找下面的符号:
;’”?。!;'".!
如果后面存在

1<p>或<br/>就分页。主要是要研究文章的格式。   

if Request.ServerVariables("Content_Length") &gt; 0 then
content = Request.Form("textarea1")

PageLength = 1000 '每页字数
CLength = Len(content)
PageCount = Int(Clength/PageLength) + 1 '计算页数

dim PageArray
redim PageArray(PageCount)

Seperator = Array(chr(13),chr(10),"。","!","?",";",",","”","’") '分隔符

PageArray(0) = 0
Pos = 0
for j=0 to ubound(Seperator)
Pos = instr(PageArray(i)+900,content,Seperator(j)) 'PageArray(i)+900 附近位置是100字,1-999可调
while Pos &gt; 0 and Pos &lt; (i+1)PageLength and Pos &gt; iPageLength
PageArray(i) = Pos
Pos = instr(Pos+PageLength,content,Seperator(j))
wend

if PageArray(i) &gt; 0 then
Response.Write "0:i¦ "&amp;PageArray(i)&amp;"<br/>"&amp;j&amp;":j"&amp;Seperator(j)&amp;"<br/>"
j = j + ubound(Seperator) + 1
end if
next

for i=1 to PageCount-1
PageArray(i) = 0
Pos = 0
for j=0 to ubound(Seperator)
Pos = instr(PageArray(i-1)+950,content,Seperator(j))
while Pos &gt; 0 and Pos &lt; (i+1)PageLength and Pos &gt; iPageLength
PageArray(i) = Pos
Pos = instr(Pos+PageLength,content,Seperator(j))
wend

if PageArray(i) &gt; 0 then
Response.Write i&amp;":i¦ "&amp;PageArray(i)&amp;"<br/>"&amp;j&amp;":j"&amp;Seperator(j)&amp;"<br/>"
j = j + ubound(Seperator) + 1
end if
next
next

output = mid(content,1,PageArray(0))
output = replace(output,chr(13),"<br/>")
Response.Write "<br/><br/>第1段<br/>"
Response.Write output

for i=1 to PageCount-2
output = mid(content,PageArray(i-1)+1,PageArray(i)-PageArray(i-1))
output = replace(output,chr(13),"<br/>")
Response.Write "<br/><br/>第"&amp;i+1&amp;"段<br/>"
Response.Write output
next

'最后一段的输出就没写了

else

1<form action="" id="form1" method="POST" name="form1">
2<textarea cols="120" id="textarea1" name="textarea1" rows="70">   
3</textarea>
4<input id="submit1" name="submit1" type="submit" value="Submit"/>
5</form>   

end if

Published At
Categories with Web编程
Tagged with
comments powered by Disqus