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

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)/]

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/3c2fe8f8f1285405ecadbc73f0e0be4b.html