首页 > 织梦dede:channelartlist嵌套dede:sql里使用当前文章变量

织梦dede:channelartlist嵌套dede:sql里使用当前文章变量

织梦dede:channelartlist嵌套dede:sql,而在dede:sql里只能使用channelartlist里的栏目变量。例如:~id~、~typeid~、~typename~。
如果想要引用当前文章的其他变量,例如:~title~、~writer~、~shorttitle~ 等等。
这些变量是不会被解析的,如果想要更多的当前文章变量,我们可以这么做。

打开“/include/taglib/channelartlist.lib.php”,找到
$pv->Fields['typeurl'] = GetOneTypeUrlA($typeids[$i]);
比如你要用到 ~title~ ,那就在它的下面加上:
$pv->Fields['title'] = $refObj->Fields['title'];

添加好以后你的dede:channelartlist嵌套dede:sql就可以这样写了
{dede:channelartlist typeid ='2,3,4,5'}
<div class="item" style="margin-top: 20px;">
 <div class="item-t">
  <div class="itc"> {dede:field name='typename'/} </div>
 </div>
 <div class="height10"></div>
 {dede:sql sql="SELECT arc.*,addf.* FROM dede_archives arc LEFT JOIN dede_addonarticle addf ON arc.id=addf.aid WHERE arc.typeid=~id~ AND arc.writer=~title~ ORDER BY arc.id ASC LIMIT 0,30}
 <div class="ilist">
  <div class="il">
   <a href="[field:id runphp=yes]$result=GetOneArchive(@me);@me=$result['arcurl'];[/field:id]" target="_blank">[field:title/]</a>
  </div>
  <div class="ir"> [field:pubdate function='strftime("%Y-%m-%d",@me)'/] </div>
 </div>
 {/dede:sql}
</div>
{/dede:channelartlist}

DedeCMS推荐
织梦采集https链接时却生成http协...
织梦后台登录出现500错误解决方案
织梦首页调用自定义表单内容方法
织梦自定义表单地区联动类型不可用的解决办...
织梦模板文档关键词维护中频率详解
织梦后台栏目显示的文档数与实际文档数不一...