加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > CMS系统 > Dedecms > 正文

织梦标签loop和sql里面的arcurl由动态变静态开发教程

发布时间:2020-12-14 04:43:58 所属栏目:Dedecms 来源:网络整理
导读:这是什么意思呢?我们知道在织梦系统里面标签调用时,最历害的二个标签就是loop和sql了,这两个可以调用织梦系统里面几乎任意表中的数据。 ? 下面将以loop标签为例子: 例如: {dede:loop table='dede_archives' orderway='asc' row='1' if='shorttitle=1'}

这是什么意思呢?我们知道在织梦系统里面标签调用时,最历害的二个标签就是loop和sql了,这两个可以调用织梦系统里面几乎任意表中的数据。

?

下面将以loop标签为例子:

例如:

{dede:loop table='dede_archives' orderway='asc' row='1' if='shorttitle=1'}

{/dede:loop}

上面这个标签调用一条,条件为shorttitle=1的文章内容,是在表dede_archives里面调用的。

??但是,调用出来的结果是: ??也就是说无论用loop?还是用sql调出来的链接都是空的,如果这样的话,这两个标签就没有意义了。

?

所以,织梦官方这样给出这样的标签调用:

{dede:loop table='dede_archives' orderway='asc' row='1' if='shorttitle=1'}

{/dede:loop}

结果是: 我们不希望在首页调用出来的内容是动态(动态链接是/plus/view.php?aid=1)的,这样可能对SEO不好,因为,多了这个链接后,同样一篇文章可能让百度收录二次,可能让百度认为是我们作弊,懂SEO都知道。

?

现在我们的目标是把底层模板[field:arcul/]的调用,跟在标签{dede:arclist}调用出来一样,即调用出来的是静态的。

例如, 经过我的研究,既然是用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'}

{/dede:loop}

??结果是:

已经变成静态的了。

如果您想使用{dede:sql}标签里面的[field:arcurl/]也变成静态的,处理方法完全一样,这里不再重复。


(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读