dedecms的万能标签loop只能调用数据表中存在的字段,对于计算得出的arcurl,就不能直接显示了,要解决这个问题,请往下看:
1.打开Include/common.func.php,在文件末尾(任意地方,我习惯在末尾,方便日后查找)增加一个自定义函数,代码如下:
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.在模板中,我们就不能像之前那样调用arcurl了,代码如下:
{dede:loop table='dede_archives' sort='' row='4' if=''} <li>·<a href='[field:id function=IDReturnURL(@me)/]'>[field:title/]</a></li> {/dede:loop}
问题已经完美解决了!
在sql标签中使用的时候,也可以这样调用了~~~