织梦likearticle标签调用附加自定义字段方法

在dedecms文章页中我们经常会显示相关文章之类的文章列表,就需要使用{dede:likearticle}标签,但是默认的likearticle是不能显示自定义的附加字段的。

第一种解决方法

打开 /include/extend.func.php ,在最下面新建一行,插入

if(!function_exists('GetAddField'))
{
	function GetAddField($aid,$addField)
	{
		global $dsql;
		$row = $dsql->GetOne("SELECT c.addtable FROM #@__archives AS a LEFT JOIN #@__channeltype AS c ON a.channel=c.id where a.id='$aid'");
		$addtable = trim($row['addtable']);
		$row = $dsql->GetOne("SELECT $addField FROM `$addtable` WHERE aid=$aid");
		return $row["$addField"];
	}
}

如图所示

 

模板中dede:likearticle调用自定义字段标签写法 

{dede:likearticle row='10' col='' titlelen='100' infolen='200'}
<a href="[field:arcurl/]">[field:title/]</a>
<p>价格:¥[field:id function=GetAddField(@me,'jiage')/]</p>
{/dede:likearticle}

 

第二种解决办法 

打开 /include/taglib/likearticle.lib.php 找到

if($keyword != '')

在它的上面加入

//获得附加表的相关信息
$addField = "";
$addJoin = "";
if(is_object($refObj->ChannelUnit))
{
    $addtable  = $refObj->ChannelUnit->ChannelInfos['addtable'];
    if($addtable!="")
    {
        $addJoin = " LEFT JOIN $addtable ON arc.id = ".$addtable.".aid ";
        $addField = "";
        $fields = explode(",",$refObj->ChannelUnit->ChannelInfos['listfields']);
        foreach($fields as $k=>$v)
        {
            $nfields[$v] = $k;
        }
        foreach($refObj->ChannelUnit->ChannelFields as $k=>$arr)
        {
            if(isset($nfields[$k]))
            {
                if(!empty($arr['rename']))
                {
                    $addField .= ",".$addtable.".".$k." as ".$arr['rename'];
                }
                else
                {
                    $addField .= ",".$addtable.".".$k;
                }
            }
        }
    }
}

继续搜索

tp.sitepath

 改成

tp.sitepath $addField

2处,都要修改,然后继续搜索 

arc.typeid=tp.id

改成

arc.typeid=tp.id $addJoin

2处,都要需改 

模板中dede:likearticle调用自定义字段标签写法

{dede:likearticle row='10' col='' titlelen='100' infolen='200'}
<a href="[field:arcurl/]">[field:title/]</a>
<p>价格:¥[field:jiage/]</p>
{/dede:likearticle}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值