织梦园模板网提供云优cms模板,pbootcms模板,Wordpress主题模板等各类企业新闻资讯网站模板下载服务。织梦园网站模板交流群
用户名:
密码:
注册
注册后享受折扣价

怎么解决dede:arclist keyword的相关问题

织梦园模板 / 2021-05-11 / 收藏

***近修改模版,为了让相关文章的相关度更高,打算优化一下,不过会增加生成页面时间,如果不经常更新倒是不错的

***近在做一个站,想做一个功能,就是有一个div块里显示的是与当前文章关键词相同的文章的标题。开始的时候是这样写的

{dede:arclist keyword='{dede:field name='keyword'}'}结果肯定是不可以的。。。。在网上找也没找到。于是就自己读代码,自己写了个简单处理的。

在arclist.lib.php 第149行

代码如下:

//关键字条件  if($keyword!='')


把{}中间的内容改成

{
	$rowGetKeyword = $dsql->GetOne("select keywords From `dede_archives` where id='$arcid'");
	$keyword=$rowGetKeyword['keywords'];
	$keyword = str_replace(',', '|', $keyword);
	$orwheres[] = " CONCAT(arc.title,arc.keywords) REGEXP '$keyword' ";
}
这样直接调用{dede:arclist keyword='这里随便写只要是不为空就可以'} 这样这里的keyword就是动态获取的了。不然只能是固定的。

就在刚刚我发帖之前看到dede5.6里有个标签

{dede:likeart titlelen='' row=''} {/dede:likeart}

这个标签还没测试,不过应该就是这个功能。如果不是,大家就一用我上面的方法。测试过了,可以用。

DEDECMS相关文章以关键字相关的修改方法

DEDE的相关文章完全不相关,有朋友在DEDE官方放出根据TAG显示相关文章,也是很不错,可惜我在根据那边文章改DEDE代码后老是不行,可能是能力有限,当然也有可能是代码有问题

现在终于出了解决办法:

1 在 inc_functions.php ***后?>前 加上

代码如下:

	//查询指定栏目里包含相应关键字的文章,并列出
	//参数说明:$showImg 是否显示缩略图,0表示不显示,1表示显示
	// $titleLen 标题长度,0表示无限
	// $rowCount 输出行数,0表示无限
	// $typeid 栏目ID,0表示所有栏目
	// $keyWord 关键字,字符串
	function ShowKeyWordArc($showImg,$titleLen,$rowCount,$typeid,$keyWord){
		$dsql = new DedeSql(false);
		$sql = TypeGetSunID($typeid,$dsql); 
		//关键字分词技术
		$ks = explode(" ",$keyWord);
		foreach($ks as $k){  $k = trim($k);  if ($k!="") {  $kwsqlarr[] = " (dede_archives.title like '%$k%')";  //$kwsqlarr[] = " (dede_archives.keywords like '%$k%') "; //如果需要相关到其它文章的关键字,解除此行注释  }  }
		$where = implode(' OR ',$kwsqlarr); 
		$sql="Select tp.namerule,tp.typedir,dede_full_search.aid,dede_full_search.url,dede_archives.* From dede_full_search left join dede_archives on dede_full_search.aid=dede_archives.ID left join dede_arctype tp on dede_archives.typeid=tp.ID where {$sql} and ((dede_archives.title like '%".$keyWord."%') or $where) order by dede_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)) return $ss;
		  }
		  return $ss;
		}

2 放在文章模板页内

{dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”@me”)’/}

就表示是取所有栏目内的相关文章(与当前文章的关键字相关),标题长度***大32,***多显示10条,不显示缩略图

{dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”高三 语文”)’/}  可以找到标题里,含有“高三 语文”,或者含有“高三”或“语文”的文章


例如,这一段:

相关文章  {dede:likeart titlelen=’24′ row=’10′} [field:textlink/]< >  {/dede:likeart}


就改成:

相关文章  {dede:field name=’keywords’ function=’ShowKeyWordArc(0,32,10,0,”@me”)’/}

申明:这个函数不是我写的

根据关键字来相关文章,就用户体验以及SEO来说都是***好的

但是***不好的地方就是生成静态的时候会慢很多,哈哈,服务器又要辛苦了

相关织梦技巧

收缩