• DEDECMS中LOOP标签循环出arcurl标签(获取链接)


    编辑器加载中...

      在DEDECMSV5.3中,提供了loop万能循环标签,但是此循环标签只能循环出该表中的字段,而“[field:arcurl/]”链接标签并不能被解析出来,而DEDECMS官方论坛上也没有找到相关的解决办法,所以只有自己动手写代码了!
    
    这是官方提供的代码:
    {dede:loop table='dede_archives' sort='' row='4' if=''}
    <a href='[field:arcurl/]'>[field:title/]</a>
    {/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=''}
    <li>·<a href='[field:id function=IDReturnURL(@me)/]'>[field:title function=cn_substrR(@me,44)/]</a></li>
    {/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]

    也可以调出来。

  • 相关阅读:
    6、函数、谓词、CASE表达式
    25. k个一组翻转链表
    78. 子集
    72. 编辑距离
    12. 整数转罗马数字
    287. 寻找重复数
    27. 移除元素
    91. 解码方法
    283. 移动零
    198. 打家劫舍
  • 原文地址:https://www.cnblogs.com/freespider/p/2223471.html
Copyright © 2020-2023  润新知