找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1313|回复: 0

[分享] DedeCMS系统datalist标签调用arcurl方法

[复制链接]
发表于 2018-3-18 09:06:13 | 显示全部楼层 |阅读模式 来自 中国–河南–新乡
DedeCMS系统datalist标签调用arcurl方法(本文未测试,请自行测试可行性),使用datalist时,无法直接调用arcurl值。arclist标记使用[field:arcurl]可以直接调出文章url,在sql标签中也可以调出文章url:

[field:id runphp='yes']$arcRow=GetOneArchive(@me);@me=$arcRow['arcurl'];[/field:id]

datalist标签不能直接调用arcurl字段,可以扩展函数。sql标签调用时GetOneArchive函数,打开include文件夹下common.func.php文件找到GetOneArchive函数:

  1.   //获取单篇文档信息

  2. function GetOneArchive($aid)
  3. {
  4. global $dsql;
  5. include_once(DEDEINC."/channelunit.func.php");
  6. $aid = trim(ereg_replace('[^0-9]','',$aid));
  7. $reArr = array();
  8.   
  9. $chRow = $dsql->GetOne("Select arc.*,ch.maintable,ch.addtable,ch.issystem
  10. From `dede_arctiny` arc
  11. left join `dede_channeltype` ch on ch.id=arc.channel where arc.id='$aid' ");
  12. if(!is_array($chRow)) {
  13.   return $reArr;
  14. }
  15. else {
  16.   if(empty($chRow['maintable'])) $chRow['maintable'] = 'dede_archives';
  17. }
  18. if($chRow['issystem']!=-1)
  19. {
  20.   $nquery = " Select arc.*,tp.typedir,tp.topid,tp.namerule,tp.moresite,tp.siteurl,tp.sitepath
  21.               From `{$chRow['maintable']}` arc left join `dede_arctype` tp on tp.id=arc.typeid
  22.               where arc.id='$aid' ";
  23. }
  24. else
  25. {
  26.   $nquery = " Select arc.*,1 as ismake,0 as money,'' as filename,tp.typedir,tp.topid,tp.namerule,
  27.   
  28. tp.moresite,tp.siteurl,tp.sitepath
  29.     From `{$chRow['addtable']}` arc left join `dede_arctype` tp on tp.id=arc.typeid
  30.               where arc.aid='$aid' ";
  31. }
  32. $arcRow = $dsql->GetOne($nquery);
  33.   
  34. if(!is_array($arcRow)) {
  35.   return $reArr;
  36. }
  37. if(!isset($arcRow['description'])) {
  38.   $arcRow['description'] = '';
  39. }
  40.   
  41. if(empty($arcRow['description']) && isset($arcRow['body'])) {
  42.   $arcRow['description'] = cn_substr(html2text($arcRow['body']),250);
  43. }
  44.   
  45. if(!isset($arcRow['pubdate'])) {
  46.   $arcRow['pubdate'] = $arcRow['senddate'];
  47. }
  48.   
  49. if(!isset($arcRow['notpost'])) {
  50.   $arcRow['notpost'] = 0;
  51. }
  52.   
  53. $reArr = $arcRow;
  54. $reArr['aid']    = $aid;
  55. $reArr['topid']  = $arcRow['topid'];
  56. $reArr['arctitle'] = $arcRow['title'];
  57. $reArr['arcurl'] = GetFileUrl($aid,$arcRow['typeid'],$arcRow['senddate'],
  58.                             $reArr['title'],$arcRow['ismake'],$arcRow['arcrank'],
  59.                             $arcRow['namerule'], $arcRow['typedir'],$arcRow['money'],
  60.                            $arcRow['filename'],$arcRow['moresite'],
  61.                            $arcRow['siteurl'],$arcRow['sitepath']);
  62. return $reArr;
  63.   
  64. }
复制代码


这里,它处理$aid返回了一个$reArr数组,此数组有arcurl这个元素,这下很好理解sql标签中调用arcurl的方法了。
找到GetOneArchive函数,打开include文件夹下extend.func.php,加入以下代码:

function getOneArchiveElement($aid,$element='arcurl'){

$arcRow=GetOneArchive($aid);

return $arcRow[$element];

}

在模板文件datalist标记里调用如下标签:

{dede:field.aid function="GetOneArchiveElement(@me,'arcurl')"}

@me是传递参数aid的功能www.genban.org

OK,这样就搞定了datalist标签中调用arcurl的问题,当然GetOneArchiveElement这个函数还可以调用其他字段的值。

发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;

如何回报帮助你解决问题的坛友,好办法就是点击帖子下方的评分按钮给对方加【金币】不会扣除自己的积分,做一个热心并受欢迎的人!

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则 需要先绑定手机号

关闭

站长推荐上一条 /1 下一条

QQ|侵权投诉|广告报价|手机版|小黑屋|西部数码代理|飘仙建站论坛 ( 豫ICP备2022021143号-1 )

GMT+8, 2024-11-24 07:15 , Processed in 0.046277 second(s), 8 queries , Redis On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表