DedeCMS(织梦)判断简略标题为空则显示完整标题的几种方法

互联网   12-06 15:45:47   作者:佚名   我要评论
最近在工作中偶然发现了一个很好用的标签,非常简单但是非常适合大家在利用dedecms开发网站的时候使用,这篇文章主要给大家介绍了关于DedeCMS(织梦)如何判断简略标题为空时就显示完整标题的几种方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考下。
前言
相信大家都遇到过,我们在使用织梦DedeCMS系统程序开发网站中,会遇到很多因网页版面设计限定的宽度,使文章标题需要进行字数限制,通常做法是在a标签中加入一个title属性,让鼠标放上去的时候显示完整标题。但是标题被剪裁掉一些字符而不完整,下面脚本之家的小编就为你推荐另外几种标题调用方式,如进行标题判断,DedeCMS判断简略标题为空时则显示完整标题。 具体方法如下: 方法一: 
{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]
这个方法可以在{dede:arclist}标签中套用。
 
方法三:
 
有时标题过长,全部显示会导致排版混乱,影响美观。但显示一部分又影响用户体验。我们希望当标题在一定长度范围内时,全标题显示,当标题过时,只显示一定长度,后面加省略号,然后当鼠标移上去时再显示标题的全部内容,这样就即做到了不影响版面的布局,又做到了标题内容的全部显示。
 
这里给出不需要修改程序,只修改模板的方法。举例,下面的标题列表,最长的标题50字节,只想显示30字节,模板代码如下:
 
<ul> {dede:arclist titlelen='50' row='10'} <li><a title="[field:title /]" href="http://sugarapple.net/quot;[field:filenam" /]">[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="http://sugarapple.net/quot" " >DedeCMS2007即将发布</a>
解释:width:120px; 限定长度,text-overflow:ellipsis :当对象内文本溢出时显示省略标记...,white-space:nowrap:强制文本在一行内显示,overflow:hidden:溢出内容为隐藏。更多相关的使用技巧大家可以参考这篇文章:http://www.jb51.net/article/50258.htm
 
CSS的方法比修改模板还要简单,不过很遗憾,text-overflow:ellipsis属性在firefox中是没有效果的。所以,还是使用上面的修改模板的方法吧。
 
最近还发现了另外一个问题,dede标题链接,有则能链接无则不连接,下面是解决的方法:
{dede:list pagesize='15' orderby='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="http://sugarapple.net/quot"'.@me['arcurl'].'" title="'.@me['description'].'" target="_blank">'.@me['title'].'</a>';}[/field:array] </dd> </dl> {/dede:list}
总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
 

相关文章

  1. dedecms实现有短标题时显示短标题、无短标题时显示长标题的方法
    这篇文章主要为大家介绍了dedecms实现有短标题时显示短标题、无短标题时显示长标题的方法,需要的朋友可以参考下
    2014-06-27
  2. Dedecms文章标题长度修改方法小结
    有时候我们在使用dedecms的时候需要修改文章标题长度,这里简单整理下,方便需要的朋友
    2013-03-01
  3. DEDECMS利发国际手机客户端:去除列表页文章标题加粗标签的方法
    就是生成的列表模板中,列表文章标题全都加粗加黑了,这样看的特别扭。解决方法代码如下
    2013-02-28
  4. 去掉织梦DedeCMS列表推荐时标题被加粗的方法
    名字被推荐后前台显示是加粗.怎么样去掉呢
    2012-07-04
  5. DEDECMS中让文章标题栏突破60个字符的方法
    怎么样让文章的标题突破60个字呢
    2012-06-13
  6. 织梦dedecms简略标题调用标签用法指南
    我们在使用织梦DEDECMS建站过程中,为了使调用的文章标题简短且相对完整(原文标题太长),只好使用了调用简略标题这个方法,使标题显示为简短标题,指向标题时显示完整的
    2011-12-26
  7. dedecms鼠标停留在标题显示完整标题
    关键字描述:标题 显示 完整 留在 鼠标 " < 可以 title field:arcurl 在文章列表中,有的标题被截断了,用什么样的代码可以让鼠标在上面的时候可以显示完整的
    2009-06-06
  8. DEDECMS鼠标移上显示全部标题的方法
    关键字描述:标题 方法 全部 显示 鼠标 "   字节 < @me"   因网页设计的原因,在某些地方我们需要截取文章的部分标题,但这样无论对SEO还是访客来说体
    2009-06-06

最新评论

利发国际手机客户端