织梦前台搜索标题和文档内容关键词实现教程

本文详细介绍如何在DEDECMS中定制搜索模块,通过修改前台模板和后台代码,实现特定模型的精确搜索,包括添加搜索参数、调整搜索逻辑等关键步骤。

实现教程

在前台模板搜索框代码内加入一行代码

<input type="hidden" name="channeltype" value="1">

例如

<form name="formsearch" action="{dede:global.cfg_cmspath/}/plus/search.php">
    <!-- 必须要指定搜索哪个模型 value="模型id" -->
    <input type="hidden" name="channeltype" value="1">
    <!-- 必须要指定搜索哪个模型 value="模型id" -->
</form>

打开 /include/arc.searchview.class.php 找到 大概在 54 行

var $Sphinx;

继续找到

$hascode = md5($cquery);

在它上面加入

if($this->ChannelType > 0)
{
	$this->AddSql = join(' AND ',$ksqls) . " AND ( CONCAT(addf.body,arc.title) LIKE '%{$this->Keyword}%') ";
	$row = $this->dsql->GetOne("SELECT addtable FROM `#@__channeltype` WHERE id={$this->ChannelType}");
	$addtable = trim($row['addtable']);
	$this->addJoin = " LEFT JOIN `{$addtable}` addf ON arc.id=addf.aid ";
	$cquery = "SELECT arc.*,addf.* FROM `{$this->AddTable}` arc {$this->addJoin} WHERE ".$this->AddSql;
}

注意:上面中的 addf.body 就是文章内容字段,如果你要搜索其他字段,改成你的自定义字段名称

继续找到

WHERE {$this->AddSql} $ordersql LIMIT $limitstart,$row";

在它下面加入

if($this->ChannelType > 0)
{
	$query = "SELECT arc.*,act.typedir,act.typename,act.isdefault,act.defaultname,act.namerule,
	act.namerule2,act.ispart,act.moresite,act.siteurl,act.sitepath,addf.*
	FROM `{$this->AddTable}` arc LEFT JOIN `#@__arctype` act ON arc.typeid=act.id {$this->addJoin}
	WHERE {$this->AddSql} $ordersql LIMIT $limitstart,$row";
}

完成

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值