DEDECMS列表页/内容页调用当前文档作者的会员头像的方法

一、实现方法 1)内容页 首先,我们知道,在内容页调用当前文档作者的ID代码为{dede:field.mid/},但这个标签只能调用出作者的mid编码。要想调用具体的文档ID,就必须对会员表(dede_mem […]



一、实现方法

1)内容页

首先,我们知道,在内容页调用当前文档作者的ID代码为{dede:field.mid/},但这个标签只能调用出作者的mid编码。要想调用具体的文档ID,就必须对会员表(dede_member)来进行检索,检索的SQL语句为:

折叠SQL 代码复制内容到剪贴板
  1. select * from dede_member where mid = 会员MID编号

刚才呢,我们已经将mid使用{dede:field.mid/}标签调用出来了,现在我们要做的就是赋值进去查询即可。故,完整代码为:

折叠XML/HTML 代码复制内容到剪贴板

引用
  1. {dede:field.mid runphp='yes'}
  2. $id = @me;
  3. if($id <> 0){
  4. $sql = "select * from dede_member where mid = $id";
  5. $query = mysql_query($sql);
  6. $row = mysql_fetch_array($query);
  7. if($row['face'] == ''){
  8. @me = '作者头像:DEDECMS列表页/内容页调用当前文档作者的会员头像的方法(图1)';
  9. }
  10. else{
  11. $face = $row['face'];
  12. @me = '作者头像:DEDECMS列表页/内容页调用当前文档作者的会员头像的方法(图2)';
  13. }
  14. }
  15. else{
  16. @me = '游客发表';
  17. }
  18. {/dede:field.mid}

2)列表页

和1)中分析的原理是完全一样的,只是在这里由于在列表页,需要赋值的不是{dede:field.mid/},而是[field:mid/]。故完整代码为:

折叠XML/HTML 代码复制内容到剪贴板

引用
  1. [field:mid runphp='yes']
  2. $id = @me;
  3. if($id <> 0){
  4. $sql = "select * from dede_member where mid = $id";
  5. $query = mysql_query($sql);
  6. $row = mysql_fetch_array($query);
  7. if($row['face'] == ''){
  8. @me = '作者头像:DEDECMS列表页/内容页调用当前文档作者的会员头像的方法(图1)';
  9. }
  10. else{
  11. $face = $row['face'];
  12. @me = '作者头像:DEDECMS列表页/内容页调用当前文档作者的会员头像的方法(图2)';
  13. }
  14. }
  15. else{
  16. @me = '游客发表';
  17. }
  18. [/field.mid]

二、分析及解释

1)本文上述代码的特点有:

  1. 对文档作者进行了判断,如果是游客投稿,则不进行查询而直接输出"游客发表",当前,这里您也可以直接置空;
  2. 对会员头像做了简单的判断,如果会员没有上传头像(即头像为空)时,则输出"/member/templets/images/dfboy.png"路径的默认图片;

2)其它说明及辅助:

  1. 本实例还有继续优化的可能性(比如会员头像为空时,判断会员的性别,对不同的姓别分别输出不同的默认头像);

加载中~