建站学习网,专业提供各类建站教程,网页素材,SEO资讯等建站资源!

网站模板_网站源码_网站素材_建站教程_建站学习网

当前位置:建站学习网 > 织梦教程 > 织梦技巧 >

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

更新时间:2015-09-26整理编辑:建站学习网阅读:0
  使用织梦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:溢出内容为隐藏。
 
  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}
 
  建站学习网为你推荐:织梦DedeCMS判断简略标题为空时则显示完整标题。

本文网址:https://www.dedexuexi.com/dedejiaocheng/zmjq/332.html

本站部分文章搜集与网络,如有侵权请联系本站,转载请说明出处。

收藏此文 赞一下!() 打赏本站

如本文对您有帮助,就请建站学习网抽根烟吧!

支付宝打赏
微信打赏
织梦DedeCms用SQL语句调用数据库任意内容
« 上一篇2015年09月24日
织梦Dedecms如何修改栏目名称长度
2015年09月24日下一篇 »
  • 迅睿CMS根据栏目id来调用栏目信息
    0阅读
    迅睿CMS如何根据栏目id来调用栏目信息?独立模块栏目函数:dr_cat_value("模块目录", 栏目ID, "输出字段")共享模块栏目函数://写法1dr_share_cat_value(栏目ID, "输出字段")//写法2{category module=share id=1}{$t.url...
  • 迅睿CMS判断语句if写法
    0阅读
    格式一{if$模板变量运算符$模板变量} 模板内容{/if}{if$aaa!=$bbb}表示前面变量值不等于后面值{/if}格式二{if$模板变量1运算符$模板变量} 模板内容1{else} 模板内容2{/if}{if$aaa!=$bbb}表示前面变量值不等于后面值{else}表示反之状态,也就是相...
  • 织梦系统怎么根据IP获取当地的天气预报
    0阅读
  • 织梦DedeCMS手机端文章内容图片设置自适应屏幕的方法
    0阅读
    织梦dedecms默认的文章内容里面的图片是固定大小的,这样在手机端里面就可能会导致图片不能完整显示,甚至把屏幕撑开,这样非常不友好,所以这里就给大家分享一个方法,让手机端的文章内容里面的图片能够自适应图片大小。 方法如下: 找到并打开手机端的文章内容页模板,将里面的{dede:field.body...
  • 织梦系统中怎么查看站长日志(蜘蛛的爬行痕迹) 网站后台日志
    0阅读
    织梦系统中怎么查看站长日志(蜘蛛的爬行痕迹) 一般空间都会独立出来一个文件夹命名为log这里就是放日志的地方 站长日志,我都在到服务器上面下载的。 织梦系统中怎么查看站长日志(蜘蛛的爬行痕迹):一般空间都会独立出来一个文件夹命名为log这里就是放日志的地方 织梦的模板怎么看网站日志:楼主可能是新手吧...
 
QQ在线咨询