先上代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
functiontable($table,$field,$id)
{
global$dsql;
$primarys=array();
$table=strpos($table,'#@_')===false?(strpos($table,'dede_')===false?''.$table:str_replace('dede_','',$table)):$table;
$dsql->Execute("me","SHOWCOLUMNSFROM`$table`");
while($r=$dsql->GetArray())
{
if($r['Key']=='PRI')$primarys[]=$r['Field'];
}
if(!empty($primarys))
{
$primary=$primarys[0];
$result=$dsql->GetOne("SELECT`$field`FROM`$table`WHERE`$primary`=$id");
}
returnisset($result[$field])?$result[$field]:'';
}

首先把上面代码放到include/extend.func.php里,如果没有这个文件就自己建立一个(放到?>前面哦)

然后我们就可以在模板里任意使用了。

使用方法:

利用自定义函数对标签进行扩展

如:

{dede:标记function='table("要调用的表名","要调用的字段",@me)'/}

这里的“标记”就是要调用的表的主键的值,常见的就是id和aid、mid、uid之类的

标签底层模板内

[field:字段function=table(“要调用的表名","要调用的字段",@me)/]

举例

例如arclist标签底层模板字段是没有body字段的,就是说不能用arclist把文章内容调用出来的,当然这种需求很少,但不是没有,现在我们就可以这样使用

{dede:arclist row='10' titlelen='24'}

[field:id function=table('addonarticle','body',@me)/]

{/dede:arclist}

免责声明:本站所有文章和图片均来自用户分享和网络收集,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系网站客服处理。

发表回复