一、实现方法
1)函数编写
注意:自定义函数的编写一般都存放在/include/extend.func.php 中,以后升级只需要备份一下这个文件即可。
打开这个文件,在文件中最后的?>上一行加入以下代码:
- function GetMemberInfos($fields,$mid){
- global $dsql;
- if($mid <= 0){
- $revalue = "Error";
- }
- else{
- $row=$dsql->GetOne("select * from dede_member where mid = '{$mid}'");
- if(!is_array($row)){
- $revalue = "Not user";
- }
- else{
- $revalue = $row[$fields];
- }
- }
- return $revalue;
- }
保存后关闭即可
2)调用方式
要使用这个函数,可以利用系统自带的function与runphp来使用。在底层模板字段中,通常使用function方法。比如:
- [field:mid function="GetMemberInfos('uname',@me)"/]
这样就可以很轻松的调用出某个会员的昵称了,那么要调用会员的用户名,则只需要将uname更换为userid即可。这里的值是支持member表的所有字段的。大致为如下一些:
1、mid 表示会员的唯一编号,由于其唯一的特性,一般用于区别会员;
2、mtype 表示会员的类型(如自带的“个人”与“企业”);
3、userid 表示会员用户名(也就是用于登陆);
4、pwd 表示用户的密码;
5、uname 表示用户的昵称;
6、sex 表示用户的性别;
7、rank 表示用户的等级(也就是后台的用户级别);
8、uptime 表示用户升级会员组的时间;
9、exptime 表示用户会员组的有效期天数;
10、money 表示用户拥有的剩余金币数量;
11、email 表示用户的注册邮箱地址;
12、scores 表示用户拥有的剩余积分数量;
13、matt 表示用户的级别(0为普通,1为推荐,10为后台超级管理员)
知道了以上的这些信息,还有什么不能调用的呢?
二、调用实例
刚才我们说到了调用方法,那么我们来看一下几个简单的实例:
1)在首页的arclist调用文档的所属会员昵称:
- {dede:arclist row='8' titlelen='20'}
- <li>标题:[field:title/] 昵称:[field:mid function="GetMemberInfos('uname',@me)"/]</li>
- {/dede:arclist}
2)在内容页的field中调用闻到那股的所属会员昵称:
- {dede:field.mid function="GetMemberInfos('uname',@me)"/}
好了,其它的情况大家去尝试一下吧。