DedeCMS(织梦)判断简略标题为空则显示完整标题的几种方法
(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun)
前言
相信大家都遇到过,我们在使用织梦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="[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
:溢出内容为隐藏。更多相关的使用技巧大家可以参考这篇文章:/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="'.@me['arcurl'].'" title="'.@me['description'].'" target="_blank">'.@me['title'].'</a>';}[/field:array] </dd> </dl> {/dede:list}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对程序员之家的支持。
相关文章
dedecms5.7后台发布文章提示“标题不能为空”的解决方法
这篇文章主要为大家介绍了dedecms5.7后台发布文章提示“标题不能为空”的解决方法,涉及针对相关文章添加部分源码的修改,是dedecms二次开发中比较实用的功能,需要的朋友可以2015-01-09- 这篇文章主要为大家介绍了Dedecms网站给图片alt属性自动调用标题的方法,是非常实用的技巧,对于网站优化有一定参考借鉴价值,需要的朋友可以参考下2015-01-09
- 这篇文章主要为大家介绍了Dedecms文章设置推荐后列表页标题自动加粗的解决方法,提供了修改底层相关代码与css设置两种解决方法,是非常实用的技巧,需要的朋友可以参考下2015-01-08
- 这篇文章主要为大家介绍了dedecms文章页上一篇与下一篇标题长度截取的方法,可通过底层代码实现截取或通过css隐藏溢出部分来实现这一效果,需要的朋友可以参考下2015-01-07
- 这篇文章主要为大家介绍了DEDECMS短标题标签调用与字数修改的方法,涉及标签的用法与修改技巧,具有一定的参考借鉴价值,需要的朋友可以参考下2014-12-25
- 这篇文章主要为大家介绍了织梦DedeCMS文章标题自动增加长尾关键词的方法,可实现建站时对文章标题的修改,是进行SEO非常实用的技巧,需要的朋友可以参考下2014-12-13
- 这篇文章主要为大家介绍了修改dedecms文章标题长度限制的方法,涉及对于数据库中标题字段的修改,在dedecms二次开发中比较具有实用价值,需要的朋友可以参考下2014-11-17
- 这篇文章主要为大家介绍了Dedecms文章标题及文章摘要长度修改的方法,提供了多种修改意见供大家根据情况进行选择,是采用dedecms建站时常用的技巧,需要的朋友可以参考下2014-11-11
- 本节主要介绍了DEDE如何调用分类及分类下文章并限制标题字数及显示条数,感兴趣的额朋友可以学习下2014-07-22
dedecms实现有短标题时显示短标题、无短标题时显示长标题的方法
这篇文章主要为大家介绍了dedecms实现有短标题时显示短标题、无短标题时显示长标题的方法,需要的朋友可以参考下2014-06-27
最新评论