dedecms自定义函数(DEDECMS相关文章以关键字相关的修改方法自定义函数)
类别:CMS系统 浏览量:466
时间:2021-10-27 10:07:48 dedecms自定义函数
DEDECMS相关文章以关键字相关的修改方法自定义函数现在终于出了解决办法:
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); </p> <p>//关键字分词技术
$ks = explode(" ",$keyWord);
foreach($ks as $k){
$k = trim($k);
if ($k!="") {
$kwsqlarr[] = " (xkzzz_archives.title like '%$k%')";
//$kwsqlarr[] = " (xkzzz_archives.keywords like '%$k%') "; //如果需要相关到其它文章的关键字,解除此行注释
}
}
$where = implode(' OR ',$kwsqlarr); </p> <p>$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>"; </p> <p>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来说都是非常好的
但是唯一不好的地方就是生成静态的时候会慢很多,哈哈,服务器又要辛苦了
您可能感兴趣
- typescript使用技巧(深入理解typescript中的infer关键字的使用)
- mysql8.0关键字段使用(MySQL 8.0新特性之隐藏字段的深入讲解)
- dedecms自定义函数(DEDECMS相关文章以关键字相关的修改方法自定义函数)
- dede执行查询语句(dede搜索关键字/tag标签不能区分大写字母的临时解决方法)
- sql语句中leftjoin的作用(sql中的left join及on、where条件关键字的区别详解)
- 数据库的创建关键字(数据库 关键字一览表)
- C#中的readonly和const关键字
- mysql字段和关键字(mySQL之关键字的执行优先级讲解)
- mysql索引优化有哪些(MySQL如何基于Explain关键字优化索引功能)
- 织梦tag标签怎样设置(织梦dede修改关键字长度的方法)
- python中匿名函数关键字(浅谈python之高阶函数和匿名函数)
- C#中的base和this关键字
- php面向对象final怎么设置(PHP面向对象程序设计中的self、static、parent关键字用法分析)
- sql中去除重复记录的关键字(sqlserver查询去掉重复数据的实现)
- mysql修改表结构的关键字(查看修改MySQL表结构命令)
- php构成方法的关键字是(PHP中的self关键字详解)
- 宁夏灵武恐龙化石发现始末(宁夏灵武恐龙化石发现始末)
- 到了岁末 临门一脚 节点,天台综合督评会目标直指 全年红(到了岁末临门一脚)
- 寒假余额不满24小时,不如来一场说走就走的亲子阅读之旅(寒假余额不满24小时)
- 省委书记出席的交流会,十位县委书记同场发言,代表公文材料的高水平(省委书记出席的交流会)
- 《刘老根3》热播,去世15年的她却再次被 伤害(去世15年的她却再次被)
- 十二星座爱情支配欲指数(十二星座爱情支配欲指数)
热门推荐
- 如何选择适合自己的云服务器(云服务器操作系统如何选择)
- docker进入容器的命令(Docker 最常用的镜像命令和容器命令详解)
- react中state的作用是什么(React中useEffect 与 useLayoutEffect的区别)
- 浏览器内核有哪些
- 宝塔linux面板部署防火墙后网页打不开报http564错误的解决办法(宝塔linux面板部署防火墙后网页打不开报http564错误的解决办法)
- thinkphp框架实例(ThinkPHP框架整合微信支付之JSAPI模式图文详解)
- css背景的属性有哪些(简述CSS中的背景属性background)
- docker socket文件丢失(解决vscode docker插件docker.socket权限问题)
- python学生管理系统与数据库(python学生管理系统学习笔记)
- 面试时在坐姿上应该注意什么