织梦添加一个函数,实现任意字段调用

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

注明:本文为星速云原创版权所有,禁止转载,一经发现将追究版权责任!

(0)
上一篇 2022年5月30日 上午3:56
下一篇 2022年5月30日 上午3:56

相关推荐

发表评论

登录后才能评论
问答社区 QQ客服
微信客服
微信客服
分享本页
返回顶部