include/arc.archives.class.php
文件中添加自定义函数,如getKeywordsLink()
。在模板中使用{dede:field name='keywords' function='getKeywordsLink(@me)'/}
调用该函数,将关键字替换为链接形式。 DEDECMS相关文章以关键字相关的修改方法(自定义函数)
在DEDECMS中,通过自定义函数实现根据关键字调用相关文章是一种常见需求,这种方法不仅有助于提升SEO效果,还能增加用户粘性,本文将详细介绍如何在DEDECMS中实现这一功能。
基本概念和准备工作
1. DEDECMS
DEDECMS(织梦内容管理系统)是一款基于PHP+MySQL的内容管理系统,广泛应用于各类网站,它具有灵活的标签系统和强大的自定义功能,能够方便地实现各种复杂的内容展示需求。
2. 自定义函数简介
在DEDECMS中,可以通过自定义函数来实现特定功能,根据关键字调用相关文章的功能,就可以通过修改或添加自定义函数来实现。
3. 准备工作
在进行代码修改前,建议备份现有文件,以防出现意外情况,确保服务器环境支持PHP和MySQL,并且已经安装好DEDECMS。
二、修改include/taglib/likearticle.lib文件
1. 找到文件路径
需要找到DEDECMS系统中的include/taglib/likearticle.lib
文件,该文件用于处理相关文章的调用逻辑。
2. 编辑文件内容
打开include/taglib/likearticle.lib
文件,可以看到如下代码:
function lib_likearticle(&$ctag,&$refObj){ global $dsql; // 属性处理 $attlist="row|12,titlelen|28,infolen|150,col|1,tablewidth|100,mytypeid|0,byabs|0,imgwidth|120,imgheight|90"; FillAttsDefault($ctag>CAttribute>Items,$attlist); extract($ctag>CAttribute>Items, EXTR_SKIP); $revalue = ''; // ...其他代码省略... }
3. 修改函数逻辑
我们需要对上述代码进行修改,使其支持按关键字调用相关文章,具体修改如下:
function lib_likearticle(&$ctag,&$refObj){ global $dsql; // 属性处理 $attlist="row|12,titlelen|28,infolen|150,col|1,tablewidth|100,mytypeid|0,byabs|0,imgwidth|120,imgheight|90"; FillAttsDefault($ctag>CAttribute>Items,$attlist); extract($ctag>CAttribute>Items, EXTR_SKIP); $revalue = ''; if(empty($tablewidth)) $tablewidth = 100; if(empty($col)) $col = 1; $colWidth = ceil(100/$col); $tablewidth = $tablewidth."%"; $colWidth = $colWidth."%"; $ids = array(); $tids = array(); $typeid = ( !empty($mytypeid) ? $mytypeid : 0 ); if(empty($typeid)) { if(!empty($refObj>Typelink>TypeInfos['reid'])) { $typeid = $refObj>Typelink>TypeInfos['reid']; } else { if(!empty($refObj>Fields['typeid'])) $typeid = $refObj>Fields['typeid']; } } if( !empty($typeid) && !ereg(',', $typeid) ) { $typeid = GetSonIds($typeid); } if(!empty($refObj>Fields['tags']) && $eregtype != 'keyword' ) { $tags = explode(',', addslashes($refObj>Fields['tags'])); $getsql = " tag like '".join("' OR tag like '", $tags)."' "; $dsql>Execute('me', "Select * Fromdede_tagindex
where $getsql "); while($arow = $dsql>GetArray('me')) { $tids[] = $arow['id']; } $tid = join(',', $tids); if($tid!='') { $dsql>Execute("me", "Select aid Fromdede_taglist
where tid in($tid) And arcrank > 1 group by aid order by aid desc limit 0, $row"); while($arow = $dsql>GetArray("me")) { $ids[] = $arow['aid']; $arcid = $refObj>Fields['aid']; } } } if($eregtype == 'tag' && count($ids) == 0 ) { return ''; } else { if(count($ids) > 0) { if(!empty($typeid)) { $typeid = " And arc.typeid in($typeid) And arc.id<>$arcid "; } $idsStr = join(',', $ids); $query = "Select arc.*,tp.typedir,tp.typename,tp.corank,tp.isdefault,tp.defaultname,tp.namerule,tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath fromdede_archives
arc left joindede_arctype
tp on arc.typeid=tp.id where arc.id in($idsStr) $typeid order by arc.id desc"; } else { $limitRow = $row count($ids); $keyword = ''; if(!empty($refObj>Fields['keywords'])) { $ks = explode(" ",$refObj>Fields['keywords']); foreach($ks as $k){ $k = trim($k); if ($k!="") { $kwsqlarr[] = " (xkzzz_archives.title like '%$k%')"; // 如果需要相关到其它文章的关键字,解除此行注释 } } $where = implode(' OR ',$kwsqlarr); $sql="Select tp.namerule,tp.typedir,xkzzz_full_search.aid,xkzzz_full_search.url,xkzzz_archives.* From xkzzz_full_search left join xkzzz_archives on xkzzz_full_search.aid=xkzzz_archives.ID left join xkzzz_arctype tp on xkzzz_archives.typeid=tp.ID where {$sql} and ((xkzzz_archives.title like '%".$keyWord."%') or $where) order by xkzzz_full_search.aid desc"; $dsql>SetQuery($sql); $dsql>Execute(); $ss=""; $i=0; while($row=$dsql>GetObject()){ $url=GetFileUrl($row>ID,$row>typeid,$row>senddate,$row>title,$row>ismake,$row>arcrank,$row>namerule,$row>typedir,$row>money); if ($showImg==0){ $ss=$ss."<LI><a href='".$url."' target=_blank>"; if ($titleLen!=0) $ss=$ss.cn_substr($row>title,$titleLen); else $ss=$ss.$row>title; $ss=$ss."</A></LI>"; } else { $ss=$ss."<LI><span class='sjdqimggl'><a href='".$url."' target=_blank>"; if ($row>litpic!="") $ss=$ss."<img src='".$row>litpic."' alt='".$row>title."' />"; else $ss=$ss."<img src='/images/titl.gif'/>"; $ss=$ss."</a></span><span class='sjdqtxttl'><a href='".$url."' target=_blank>"; if ($titleLen!=0) $ss=$ss.cn_substr($row>title,$titleLen); else $ss=$ss.$row>title; $ss=$ss."</A></span></LI>"; } $i++; if (($rowCount!=0)&&($i>=$rowCount)) break; } } } } }
使用自定义函数调用相关文章
1. 在模板文件中调用
在DEDECMS的模板文件中,可以使用以下代码来调用相关文章:
{dede:arclist row='12' titlelen='28' infolen='150' col='1' tablewidth='100%' mytypeid='6' typeid='1,8,12' keyword='关键字1,关键字2'} <a href="[field:arcurl/]">[field:title/]</a> {/dede:arclist}
2. 参数说明
channelid
模型ID,默认为商品模型(6),文章模型(1)。
typeid
:指定栏目ID,多个栏目用逗号分隔。
keyword
:指定关键字,多个关键字用逗号分隔。
row
:显示行数。
titlelen
长度。
infolen
:摘要长度。
col
:列数。
tablewidth
:表格宽度。
mytypeid
:栏目ID,多个栏目用逗号分隔。
typeid
:指定栏目ID,多个栏目用逗号分隔。
keyword
:指定关键字,多个关键字用逗号分隔。
常见问题与解决方案
问题1:调用相关文章时没有结果怎么办?
答:如果调用相关文章时没有结果,请检查以下几点:
1、关键字是否正确:确保关键字拼写正确且存在于数据库中。
2、栏目ID是否正确:确保指定的栏目ID存在且包含相关文章。
3、缓存问题:尝试更新系统缓存,确保最新配置生效。
4、数据库查询错误:查看系统日志,确认是否有数据库查询错误。
问题2:如何优化相关文章的显示效果?
答:要优化相关文章的显示效果,可以从以下几个方面入手:
1、调整显示样式:通过CSS调整文章列表的显示样式,如字体大小、颜色、间距等。
2、增加图片展示:在列表项中加入文章缩略图,提高视觉效果。
3、分页显示:如果相关文章较多,可以加入分页功能,避免一页加载过多内容。
4、个性化推荐:结合用户行为数据,提供个性化的相关文章推荐。
5、动态加载:使用AJAX技术实现相关文章的动态加载,提高页面加载速度和用户体验。
6、响应式设计:确保相关文章列表在不同设备上的显示效果一致,提高用户体验。
7、数据分析:定期分析相关文章的点击率和转化率,优化关键字和算法,提高推荐的准确性和有效性。
8、交互设计:增加用户反馈机制,如点赞、评论等功能,提高用户参与度和互动性。
9、安全性考虑:确保相关文章的调用和显示过程不会导致XSS攻击等安全问题。
10、性能优化:优化SQL查询语句,减少数据库负载,提高系统性能。
11、测试与监控:在上线前进行充分测试,确保功能正常;上线后持续监控,及时发现并解决问题。
12、文档编写:编写详细的开发文档和使用说明,方便后续维护和升级。
13、社区交流:积极参与DEDECMS社区交流,获取最新的技术支持和经验分享。
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。