先上代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
function?table($table,?$field,?$id)
{
????global?$dsql;
????$primarys?=?array();
????$table?=?strpos($table,?'#@_')?===?false?(strpos($table,?'dede_')?===false?''.$table:str_replace('dede_','',$table)):$table;
????$dsql?->?Execute("me","SHOW?COLUMNS?FROM?`$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");
????}
????return?isset($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}