![DEDECMS中LOOP标签循环出arcurl标签(获取链接),第1张 DEDECMS中LOOP标签循环出arcurl标签(获取链接),第1张](/aiimages/DEDECMS%E4%B8%ADLOOP%E6%A0%87%E7%AD%BE%E5%BE%AA%E7%8E%AF%E5%87%BAarcurl%E6%A0%87%E7%AD%BE%28%E8%8E%B7%E5%8F%96%E9%93%BE%E6%8E%A5%29.png)
DEDECMS中LOOP
标签循环出arcurl标签(获取链接)
在织梦DEDECMSV5.3中,提供了loop万能
循环标签,但是此循环标签只能循环出该表中的字段,而“[field:arcurl/]”链接标签并不能被解析出来,而织梦DEDECMS官方论坛上也没有找到相关的解决办法,所以只有自己动手写
代码了!
这是官方提供的代码:
{dede:loop table='dede_archives' sort='' row='4' if=''}
[field:title/]
{/dede:loop}
以下是我的解决方案:
1.打开Include/common.func.php,找到54行,再这里添加一个函数代码如下:
function IDReturnURL($ID)
{
global $dsql;
$query = "Select arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,
tp.defaultname,tp.namerule,tp.moresite,tp.siteurl,tp.sitepath
from dede_archives arc left join dede_arctype tp on arc.typeid=tp.id where arc.id = ".$ID;
$row = $dsql->GetOne($query);
$ReturnURL = GetFileUrl($row['id'],$row['typeid'],$row['senddate'],$row['title'],$row['ismake'],
$row['arcrank'],$row['namerule'],$row['typedir'],$row['money'],$row['filename'],$row['moresite'],$row['siteurl'],$row['sitepath']);
return $ReturnURL;
}
2.而在模板中我们的调用方式的写法也有所改变,代码如下:
{dede:loop table='dede_archives' sort='' row='4' if=''}
·[field:title function=cn_substrR(@me,44)/]
{/dede:loop}
问题已经完美解决了!
同样的当你要用自定义sql 标签的时候,也是一样的。
其实,就是用[field:id function=IDReturnURL(@me)/]代替了[field:arcurl/]标签,我解决此问题的核心就是[field:id function=IDReturnURL(@me)/]和IDReturnURL!
在sql标签中
[field:id runphp='yes']$arcRow=GetoneArchive(@me);@me=$arcRow['arcurl'];[/field:id]
也可以调出来。
评论列表(0条)