先上代码
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} |