这是什么意思呢?我们知道在织梦系统里面标签调用时,最历害的二个标签就是loop和sql了,这两个可以调用织梦系统里面几乎任意表中的数据。
下面将以loop标签为例子:
例如:
{dede:loop table='dede_archives' orderway='asc' row='1' if='shorttitle=1'}
<h1><a href='[field:arcurl/]'>[field:title/]</a></h1>
{/dede:loop}
上面这个标签调用一条,条件为shorttitle=1的文章内容,是在表dede_archives里面调用的。
但是,调用出来的结果是:<h1><a href=''>织梦教程网</a></h1>
也就是说无论用loop 还是用sql调出来的链接都是空的,如果这样的话,这两个标签就没有意义了。
所以,织梦官方这样给出这样的标签调用:
{dede:loop table='dede_archives' orderway='asc' row='1' if='shorttitle=1'}
<h1><a href='/plus/view.php?aid=[field:id/]' target='_blank'>[field:title/]</a><br></h1>
{/dede:loop}
结果是:<h1><a href='/plus/view.php?aid=1'>织梦教程网</a></h1>
我们不希望在首页调用出来的内容是动态(动态链接是/plus/view.php?aid=1)的,这样可能对seo不好,因为,多了这个链接后,同样一篇文章可能让百度收录二次,可能让百度认为是我们作弊,懂seo都知道。
现在我们的目标是把底层模板[field:arcul/]的调用,跟在标签{dede:arclist}调用出来一样,即调用出来的是静态的。
例如,<h1><a href='www.dede58.com/php/1.html'>织梦教程网</a></h1>
经过我的研究,既然是用loop就改他的标签源码文件: loop.lib.php
在这个文件里面找到这样一行代码:$dsql->SetQuery("SELECT * FROM $tablename $ifcase $sort LIMIT 0,$row");
注释掉(或删除掉)
然后,加上下面这行代码:
$dsql->SetQuery("SELECT arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule, tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath FROM `$tablename` arc LEFT JOIN `dede_arctype` tp on arc.typeid=tp.id $ifcase $sort LIMIT 0,$row"); |
然后,
在代码:
while($row = $dsql->GetArray())
{
里面加上下面这行代码:
$row['arcurl'] = GetFileUrl($row['id'],$row['typeid'],$row['senddate'],$row['title'],$row['ismake'], $row['arcrank'],$row['namerule'],$row['typedir'],$row['money'],$row['filename'],$row['moresite'],$row['siteurl'],$row['sitepath']);
保存!
现在再来使用用标签:
{dede:loop table='dede_archives' orderway='asc' row='1' if='shorttitle=1'}
<h1><a href='[field:arcurl/]'>[field:title/]</a></h1>
{/dede:loop}
结果是:
<h1><a href='www.dede58.com/php/1.html' >织梦教程网</a></h1>
已经变成静态的了。
如果您想使用{dede:sql}标签里面的[field:arcurl/]也变成静态的,处理方法完全一样,这里不再重复。