这里是普通文章模块栏目内容页
织梦系统中 @me 实现原理及其使用详细分析
相信很多朋友都遇到过织梦系统dedecms里面的 @me 了吧。
 
例如,在织梦模板list_article.htm里面,有这样一段使用@me的标签:
 
[field:array runphp='yes']@me = (empty(@me['litpic']) ? "" : "<a href='{@me['arcurl']}' class='preview'><img src='{@me['litpic']}'/></a>"); [/field:array]
复制代码
 
  这段代码是用在底层模板是{dede:list}...{/dede:list}之间的。
 
  这段底层模板的作用是:判断一下我们在后台发布的内容是不是有缩略图,如果没有的话缩略图就不会显示,否则,在调用处显示缩略图。
 
  这里面就使用了@me的功能,很多人遇到过但是,真正的理解的人可能不多,一般人都知道@me表示当前值,但是,真正的使用时就不知道如何使用,或是完全不知道做什么用的,一方面是因为织梦官方没有提供教程,另一方面是因为这个用的不多,但是,这个@me用好了,可以做很多事,而且,其实,设计原理也非常好,特别对于做织梦二次开发的或是自己写系统的都很有借鉴意义,有必要详细讲解一下这个@me实现原理及其使用。
 
  要把@me这个弄明白实现的原理以及它的使用,就要把这个相关的代码研究透彻,源码才是真正理解一个功能的最重要的参考。
 
  上面这段代码表示使用织梦提供的php接口,从runphp='yes'就可以可以上面这段代码表示运行php接口,如果不理解的话,请接着向下看,不用管什么接口,什么使用php接口,把下面我分析的内容弄明白了就理解了。
 
@me调用缩略图的实现原理:
 
  @me['litpic']表示调用织梦dedecms系统主表dede_archvies里面的字段litpic的值,主表如下图所示:
我们就以文章id为28的记录作为例子,后面在分析代码时我们就以这条数据为例子,并且,请注意这个主表中的每个字段。
 
  litpic字段对应的值就是我们在后台添加文章时添加的,如下图所示:
为什么用@me['arcurl']能够调用出织梦主表dede_archvies里面对应的字段litpic的字段值,即缩略图呢?织梦是如何实现的?
 
  从这里面可以看出@me就像一个数组,在这个数组里面包含了主表dede_archives里面的字段值,类似 array('litpic'=>'/dedecms/uploads/170411/1-1F41111394Q57.png','id'=>"92",'typeid'=>2,.....),真的是这样吗?
 
  如果@me真的如上面所分析的应当是一个包含主表中字段的数组的话,如果真是这样的话,那我要调用id为28的文章对对应的栏目typeid的值,是不是只需要这样调用@me['typeid']就可以获取到值为2了,如果真这样的话,那太历害了,主表中的字段我就可以完全自由调用。
 
  这非常类似php里面的一个数组的调用,例如,$arr = array('a' => 1,'b'=>3,'c'=>4 ),我想调用数组中的b的值,只需要这样调用 $arr['b'] 即可获取到键b对应的值为3。
 
  真的如上面所分析的@me就是一个包含主表中字面的数组吗? 请看下面的分析。
 
  我们知道织梦生成html代码是通过织梦的模板引擎来实现的,也就是由/include/dedetag.class.php静态模板引擎来实现的。
 
  那上面这段代码:
[field:array runphp='yes']@me = (empty(@me['litpic']) ? "" : "<a href='{@me['arcurl']}' class='preview'><img src='{@me['litpic']}'/></a>"); [/field:array]
复制代码
 
  也是由文件dedetag.class.php来处理的,在这个文件里面找到这样一个函数:RunPHP(&$refObj, $i)
 
  函数RunPHP(&$refObj, $i)的作用就是解释上面的这段代码。
 
 
    function RunPHP(&$refObj, $i)
    {
        $DedeMeValue = $phpcode = '';
        if($refObj->GetAtt('source')=='value')
        {
            $phpcode = $this->CTags[$i]->TagValue;
        }
        else
        {
            $DedeMeValue = $this->CTags[$i]->TagValue;
            $phpcode = $refObj->GetInnerText();
            
        }
        $phpcode = preg_replace("/'@me'|"@me"|@me/i", '$DedeMeValue', $phpcode);
    .......
        $this->CTags[$i]->TagValue = $DedeMeValue;
        $this->CTags[$i]->IsReplace = TRUE;
    }
 
  在这个函数里面一般都是执行else里面的代码,即:
 
            $DedeMeValue = $this->CTags[$i]->TagValue;
            $phpcode = $refObj->GetInnerText();
复制代码
 
  我们来分析一下这两行是做什么的。
 
  $this->CTags[$i]->TagValue:这行代码表示获取当前id(假设以文章id值为28作为例子)为28的文章对应主表里面的字段键值对,也就是一个如下所示的数组$DedeMeValue:
 
array (
  'id' => string '92' (length=2)
  'typeid' => string '2' (length=1)
  'typeid2' => string '0' (length=1)
  'sortrank' => string '1491881978' (length=10)
  'flag' => string 'p' (length=1)
  'ismake' => string '0' (length=1)
  'channel' => string '1' (length=1)
  'arcrank' => string '0' (length=1)
  'click' => string '170' (length=3)
  'money' => string '0' (length=1)
  'title' => string 'DedeCMS V5.6 开发日志及新建议提交贴' (length=46)
  'shorttitle' => string '' (length=0)
  'color' => string '' (length=0)
  'writer' => string '织梦官方' (length=12)
  'source' => string '织梦官方' (length=12)
  <font color="Red"><b>'litpic' => string '/dedecms/uploads/170411/1-1F41111394Q57.png'</b></font>
  'pubdate' => string '1491881978' (length=10)
  'senddate' => string '1270623040' (length=10)
  'mid' => string '1' (length=1)
  'keywords' => string '建议,提交,贴,新,日志,V5.6,开发,DedeCMS,' (length=49)
  'lastpost' => string '0' (length=1)
  'scores' => string '0' (length=1)
  'goodpost' => string '0' (length=1)
  'badpost' => string '0' (length=1)
  'voteid' => string '0' (length=1)
  'notpost' => string '0' (length=1)
  'description' => string '说明: ■为已经升级或修正的功能 □表示需多处同时处理的复杂功能或待验证功能 [新增] ■ 1.搜索关键词批量管理功能; □ 2.会员中心更换全新UI界面,让用户中心更亲切方便; ■ 2.1 会员中心增' (length=255)
  'filename' => string '/dedecms/a/webbase/html/2010/0407/92.html' (length=41)
  'dutyadmin' => string '1' (length=1)
  'tackid' => string '0' (length=1)
  'mtype' => string '0' (length=1)
  'weight' => string '90' (length=2)
  'typedir' => string '{cmspath}/a/webbase/html' (length=24)
  'typename' => string 'HTML' (length=4)
  'corank' => string '0' (length=1)
  'isdefault' => string '1' (length=1)
  'defaultname' => string 'index.html' (length=10)
  'namerule' => string '{typedir}/{Y}/{M}{D}/{aid}.html' (length=31)
  'namerule2' => string '{typedir}/list_{tid}_{page}.html' (length=32)
  'ispart' => string '0' (length=1)
  'moresite' => string '0' (length=1)
  'siteurl' => string '' (length=0)
  'sitepath' => string '{cmspath}/a/webbase' (length=19)
  'infos' => string '说明: ■为已经升级或修正的功能 □表示需多处同时处理的复杂功能或待验证功能 [新增] ■ 1.搜索关键词批量管理功能; □ 2.会员中心更换全新UI界面,让用户中心更亲切方便; ■ 2.1 会员中心增' (length=255)
  'arcurl' => string '/dedecms/a/webbase/html/2010/0407/92.html' (length=41)
  'typeurl' => string '/dedecms/a/webbase/html/' (length=24)
  'picname' => string '/dedecms/uploads/170411/1-1F41111394Q57.png' (length=43)
  'stime' => string '2017-04-11' (length=10)
  'typelink' => string '<a href='/dedecms/a/webbase/html/'>HTML</a>' (length=43)
  'image' => string '<img src='/dedecms/uploads/170411/1-1F41111394Q57.png' border='0' width='120' height='120' alt='DedeCMS V5.6 开发日志及新建议提交贴'>' (length=144)
  'imglink' => string '<a href='/dedecms/a/webbase/html/2010/0407/92.html'><img src='/dedecms/uploads/170411/1-1F41111394Q57.png' border='0' width='120' height='120' alt='DedeCMS V5.6 开发日志及新建议提交贴'></a>' (length=200)
  'fulltitle' => string 'DedeCMS V5.6 开发日志及新建议提交贴' (length=46)
  'textlink' => string '<a href='/dedecms/a/webbase/html/2010/0407/92.html'>DedeCMS V5.6 开发日志及新建议提交贴</a>' (length=102)
  'phpurl' => string '/dedecms/plus' (length=13)
  'plusurl' => string '/dedecms/plus' (length=13)
  'memberurl' => string '/dedecms/member' (length=15)
  'templeturl' => string '/dedecms/templets' (length=17)
 
)
复制代码
$refObj->GetInnerText():表示获取底层模板[field:array runphp='yes']和[/field:array]之间的内容,
 
  也就是获取的内容是:@me = (empty(@me['litpic']) ? "" : "<a href='{@me['arcurl']}' class='preview'><img src='{@me['litpic']}'/></a>");
 
  把这行内容赋给$phpcode。
 
  通过替换函数str_replace,即preg_replace("/'@me'|"@me"|@me/i", '$DedeMeValue', $phpcode)进行替换。
 
  因为,$DedeMeValue是上面列出id为28的数组,通过上面的替换函数,把@me全部替换为$DedeMeValue。
 
  替换后的结果:
$DedeMeValue = (empty($DedeMeValue['litpic']) ? "" : "<a href='{$DedeMeValue['arcurl']}' class='preview'><img src='{$DedeMeValue['litpic']}'/></a>");
复制代码
 
  $DedeMeValue['litpic']结果是什么,这不正是后台添加到主表中的缩略图,即主表中litpic对应的值:/dedecms/uploads/170411/1-1F41111394Q57.png
 
  所以底层模板中empty(@me['litpic'])意思是判断一下缩略图是否为空,若不为空则调出一个缩略图来。
 
  通过上面的分析可以知道,那如果我想调用id=28对应的栏目id只需要使用 @me['typeid']即可,不防测试一下。