首页 > 网站制作
一言推荐::D 获取中...

dedecms标题过长,截断标题加省略号的实现方法

网站制作/ 2018-05-16/

  有时标题过长,全部显示会导致排版混乱,影响美观.但显示一部分又影响用户体验.我们希望当标题在一定长度范围内时,全标题显示,当标题过时,只显示一定长度,后面加省略号,然后当鼠标移上去时再显示标题的全部内容,这样就即做到了不影响版面的布局,又做到了标题内容的全部显示.
 
  这里给出不需要修改程序,只修改模板的方法.举例,下面的标题列表,最长的标题50字节,只想显示30字节,模板代码如下:
 
  <ul>
  {dede:arclisttitlelen='50'row='10'}
  <li><atitle="[field:title/]"href="[field:filename/]">[field:titlefunction='(strlen("@me")>30?cn_substr("@me",30)."...":"@me")'/]</a></li>
  {/dede:arclist}
  </ul>
 
  很明显,解决问题的关键在于用[field:titlefunction='(strlen("@me")>30?cn_substr("@me",30)."...":"@me")'/]代替了原来的[field:title/],在输出标题时多了一个判断的过程,先判断标题是否大于30字节,如果大于则只输出30字节的长度,并加上省略号.而title="[field:title/]"则不受影响,鼠标移上去时显示标题的全部内容.
 
  除上面修改模板的方法外,还有编程或CSS等方法.但能通过模板解决的问题,编程就不必要了.CSS的方法如下:
 
  <astyle="width:120px;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;"title="DedeCMS2007即将发布"href="">DedeCMS2007即将发布</a>
 
  解释:width:120px;限定长度,text-overflow:ellipsis:当对象内文本溢出时显示省略标记...,white-space:nowrap:强制文本在一行内显示,overflow:hidden:溢出内容为隐藏.
 
  CSS的方法比修改模板还要简单,不过很遗憾,text-overflow:ellipsis属性在firefox中是没有效果的.所以,还是使用上面的修改模板的方法吧.
 
  

TAGS:

打赏 点赞
邮箱
验证码
昵称