muban大师 发表于 2021-2-8 11:02:42

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

先上代码
       
        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;
                $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之类的
       
        标签底层模板内
       
       
       
       
        举例
       
        例如arclist标签底层模板字段是没有body字段的,就是说不能用arclist把文章内容调用出来的,当然这种需求很少,但不是没有,现在我们就可以这样使用
       
       
       
        {dede:arclist row='10' titlelen='24'}
       
       
       
        {/dede:arclist}
页: [1]
查看完整版本: 织梦添加一个函数,实现任意字段调用