首页 > CMS > 织梦DEDE > 正文

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

2024-07-12 08:48:49
字体:
来源:转载
供稿:网友
这篇文章主要为大家详细介绍了织梦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}

完成。有兴趣了解的朋友可以自己动手尝试看看。

扩展阅读

《织梦channelartlist标签调用外部链接导航时无法显示的解决方法》

《织梦dede:channel、dede:channelartlist支持调用隐藏栏目》

以上就是织梦dede:channelartlist嵌套dede:sql如何使用当前文章变量的全部内容,希望对大家的学习和解决疑问有所帮助,也希望大家多多支持武林网。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表