在织梦CMS v5.7 中打开官方默认模板article_artcile.htm,我们可以提取调用文章所属会员信息标签的代码
{dede:memberinfos}
会员头像:
会员用户名:[field:uname/]
会员详细资料:查看详细资料
给他留言:发送留言
加为好友:加为好友
用户等级:[field:rankname /]
注册时间:[field:jointime function="MyDate('Y-m-d H:m',@me)"/]
最后登录:[field:logintime function="MyDate('Y-m-d H:m',@me)"/]
{/dede:memberinfos}
|
用户信息(memberinfos) 用户信息标签的适用范围是全局使用,之所以把它归档到内容页来讲,是因为这个标签在内容页的使用更加普遍。 该标签是属于有底层模板的调用标签,它有且只有一个参数 mid = '1' 指定要获取的用户ID 如果在文档阅读页,该参数为空的话,那么就默认指定该文档的发布者会员ID,通常用来调用“发布者资料”类似功能。其完整代码为:
{dede:memberinfos} 昵称:[field:uname/] {/dede:memberinfos}
|
底层模板的取值范围是:dede_member所有字段及spacename(空间名称)、sign(用户签名)
5.1版本:
1.在内容页加 如下代码:
本文作者:{dede:memberinfo /}
2.然后找到include/inc_archives_view.php 把原来的添加如下的代码
5.3版本:
1.在内容页加 如下代码:
本文作者:{dede:memberinfo /}
2.然后找到include/arc.archives.class.php 把原来的添加如下的代码
//----------------------
//获得本文的投稿作者信息
//----------------------
function GetMemberInfo()
{
if(!isset($this->MemberInfos['ID'])){
if($this->Fields['memberID']==0) return '';
else{
$this->MemberInfos = $this->dsql->GetOne("Select ID,userid,uname,spacename,spaceimage From dede_member where ID='{$this->Fields['memberID']}' ");
}
}
if(!isset($this->MemberInfos['ID'])) return "";
else{
$minfo = "MemberInfos['userid']."&action=memberinfo'>";
$minfo .= $this->MemberInfos['uname']."rn";
$minfo .= "MemberInfos['userid']."&action=feedback'>留言rn";
$minfo .= "空间:MemberInfos['userid']."'>";
$minfo .= $this->MemberInfos['spacename']."rn";
return $minfo;
}
}
---------------------------
|
DEDECMS列表页/内容页调用当前文档作者的会员头像的方法
一、实现方法
1)内容页
首先,我们知道,在内容页调用当前文档作者的ID代码为{dede:field.mid/},但这个标签只能调用出作者的mid编码。要想调用具体的文档ID,就必须对会员表(dede_member)来进行检索,检索的SQL语句为:
折叠SQL 代码复制内容到剪贴板
select * from dede_member where mid = 会员MID编号
刚才呢,我们已经将mid使用{dede:field.mid/}标签调用出来了,现在我们要做的就是赋值进去查询即可。故,完整代码为:
{dede:field.mid runphp='yes'}
$id = @me;
if($id <> 0){
$sql = "select * from dede_member where mid = $id";
$query = mysql_query($sql);
$row = mysql_fetch_array($query);
if($row['face'] == ''){
@me = '作者头像:';
}
else{
$face = $row['face'];
@me = '作者头像:';
}
}
else{
@me = '游客发表';
}
{/dede:field.mid}
|
2)列表页
和1)中分析的原理是完全一样的,只是在这里由于在列表页,需要赋值的不是{dede:field.mid/},而是[field:mid/]。故完整代码为:
[field:mid runphp='yes']
$id = @me;
if($id <> 0){
$sql = "select * from dede_member where mid = $id";
$query = mysql_query($sql);
$row = mysql_fetch_array($query);
if($row['face'] == ''){
@me = '作者头像:';
}
else{
$face = $row['face'];
@me = '作者头像:';
}
}
else{
@me = '游客发表';
}
[/field.mid]
|
二、分析及解释
1)本文上述代码的特点有:
对文档作者进行了判断,如果是游客投稿,则不进行查询而直接输出“游客发表”,当前,这里您也可以直接置空;
对会员头像做了简单的判断,如果会员没有上传头像(即头像为空)时,则输出“/member/templets/images/dfboy.png”路径的默认图片;
2)其它说明及辅助:
本实例还有继续优化的可能性(比如会员头像为空时,判断会员的性别,对不同的姓别分别输出不同的默认头像);