从数据库中提取长长的文章,总是有碍网页的排版布局。

所以,想固定地提取一部分字符,然后后面有……替代。

1,原理:
判断文章的长度是否超过规定的长度,若超过则只显示规定长度的大学,否则完整显示。

2,涉及函数:

len():返回字符串长度或者变量的字节长度。

[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
left():截取一个字符串的前部分

[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
3,主要程序:判断内容长度是否大于给定值,据结果做相应操作

[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]

4,ASP中应用
以上是在客户端脚本调试,和ASP也是大同小异:最主要的是函数功能。


<%
text=rs(“content”)  ‘将数据库字段值赋到某变量上
i=10                      ‘定义固定大小
if len(text)>i then   ‘如果文本长度大于给定的值
text=left(text,i)     ‘则提取前段的i位的字符串
response.write (text&”…”)
else
response.write (text)
end if
%>


5,为了方便,做成函数


<%
function conleft(content,i)
if len(content)>i then  
content=left(content,i)    
response.write (content&”…”)
else
response.write (content)
end if
end function
%>


以上为函数,下面就可以直接调用。



OK,相信以后遇到这些问题应该是NO PROBLEM 

为了解决中英文截取的问题,建议大家使用如下函数:


Function gotTopic(str,strlen)
    if str=”” then
        gotTopic=””
        exit function
    end if
    dim l,t,c, i
    str=replace(replace(replace(replace(str,””,” “),”"”,chr(34)),”>”,”>”),”<“,”<")
    l=len(str)
    t=0
    for i=1 to l
        c=Abs(Asc(Mid(str,i,1)))
        if c>255 then
            t=t+2
        else
            t=t+1
        end if
        if t>=strlen then
            gotTopic=left(str,i) & “…”
            exit for
        else
            gotTopic=str
        end if
    next
    gotTopic=replace(replace(replace(replace(gotTopic,” “,””),chr(34),”"”),”>”,”>”),”<","<")
End Function