欢迎来到258分享网,纯净的网络源码分享基地!

258资源分享网

全部作品
全部作品
网站源码
微信源码
素材特效
源码插件
视频教程
建站学院
热门搜索: 织梦  农业种植  农业  安全设置  官方
258资源分享 > 建站学院 > 织梦教程 > 织梦DedeCMS判断简略标题为空时则显示完整标题

推荐下载

HTML5响应式自适应网咯设计

2020-05-12   浏览:740

高端HTML5响应式企业通用网

2020-05-06   浏览:521

html5响应式外贸网站英文版

2020-05-08   浏览:510

HTML5自适应律师工作室类网

2020-04-04   浏览:504

HTML5影视传媒文化公司类网

2020-05-12   浏览:500

织梦DedeCMS判断简略标题为空时则显示完整标题

发布时间:2020-08-27  

使用织梦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=http://www.dede58.com/a/dedejq/"[field:title /]" href=http://www.dede58.com/a/dedejq/"[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=http://www.dede58.com/a/dedejq/"[field:title /]" 则不受影响,鼠标移上去时显示标题的全部内容。

 

方法四:

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

 

<a style=http://www.dede58.com/a/dedejq/"width:120px; text-overflow:ellipsis; white-space:nowrap; overflow:hidden;" title=http://www.dede58.com/a/dedejq/"DedeCMS2007即将发布" href=http://www.dede58.com/a/dedejq/" " >DedeCMS2007即将发布</a>

 

解释:width:120px; 限定长度,text-overflow:ellipsis :当对象内文本溢出时显示省略标记...,white-space:nowrap:强制文本在一行内显示,overflow:hidden:溢出内容为隐藏。

 

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://www.dede58.com/a/dedejq/"'.@me['arcurl'].'" title=http://www.dede58.com/a/dedejq/"'.@me['description'].'" target=http://www.dede58.com/a/dedejq/"_blank">'.@me['title'].'</a>';}[/field:array]      

         

         

         </dd>

        </dl>