码迷,mamicode.com
首页 > 其他好文 > 详细

DEDE无简略标题时显示完整标题

时间:2015-04-04 14:52:25      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:

新闻的标题需要进行字数限制,这就需要加入一个title属性,让鼠标放上去的时候显示完整标题。另外目前的调用只能同时调用一种标题方式,不过可 以采用以下方法,进行判断,无简略标题显示完整标题。例如dede早期版本中的”有来源显示来源,无来源不显示”、”有作者显示作者,无作者不显示”。

这是有长标题显示长标题,无长标题则显示短标题,需要反过来用的,可以把shorttitle和title互换一个位置.

方法一:

{dede:field name=array‘ runphp=yes‘} if (@me[shorttitle‘]==‘‘) @me=@me[title‘];else @me=@me[shorttitle‘];{/dede:field} 

     


方法二:

[field:array runphp=yes‘] if (@me[shorttitle‘]==‘‘) @me=@me[title‘];else @me=@me[shorttitle‘];[/field:array]

 

方法二(附):

 [field:array runphp=yes‘] if (@me[title‘]==‘‘) @me=@me[shorttitle‘];else @me=@me[title‘];[/field:array]

 

这个方法可以在{dede:arclist}标签中套用。

方法三:
有时标题过长,全部显示会导致排版混乱,影响美观。但显示一部分又影响用户体验。我们希望当标题在一定长度范围内时,全标题显示,当标题过时,只显示一定 长度,后面加省略号,然后当鼠标移上去时再显示标题的全部内容,这样就即做到了不影响版面的布局,又做到了标题内容的全部显示。

这里给出不需要修改程序,只修改模板的方法。举例,下面的标题列表,最长的标题50字节,只想显示30字节,模板代码如下:

           <ul>
                {dede:arclist titlelen=50‘ row=10}
                <li><a title="[field:title /]" href="[field:filename /]">[field:title function=( strlen("@me")>30 ? cn_substr("@me",30)."..." : "@me" )‘/]</a></li>
                {/dede:arclist}
            </ul>

 

很明显,解决问题的关键在于用 [field:title function=‘( strlen("@me")>34 ? cn_substr("@me",30)."..." : "@me" ) ‘ /] 代替了原来的 [field:title /] ,在输出标题时多了一个判断的过程,先判断标题是否大于34字节,如果大于则只输出30字节的长度,并加上省略号。而title=" [field:title /]" 则不受影响,鼠标移上去时显示标题的全部内容。

方法四:
除上面修改模板的方法外,还有编程或CSS等方法。但能通过模板解决的问题,编程就不必要了。CSS的方法如下:

<a style="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中是没有效果的。所以,还是使用上面的修改模板的方法吧。

dede标题链接,有则能链接无则不连接

技术分享
{dede:list pagesize=15orderby=weight‘ orderway=desc}
        <dl>
         <dt>[field:pubdate function=strftime("%Y/%m/%d",@me)‘/]</dt>
         <dd>
   
[field:array runphp=yes‘] if (@me[body‘]==‘‘) @me=@me[title‘];else{ @me = <a href="‘.@me[arcurl‘]." title="‘.@me[description‘]." target="_blank">‘.@me[title‘].</a>‘;}[/field:array]     
        
        
         </dd>
        </dl>
        {/dede:list}
技术分享

DEDE无简略标题时显示完整标题

标签:

原文地址:http://www.cnblogs.com/onlylove2015/p/4392046.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!