帝国cms小程序源码 帝国CMS搜索表单制作教程

帝国CMS教程

帝国cms内置强大的搜索功能,用户只需制作搜索表单指向搜索处理页面即可实现相应搜索。本文讲解:搜索表单制作语法。

搜索表单的变量说明

 

 

变量名 说明 例子
搜索表单提交地址 POST方式:/e/search/index.php <form name="searchform" method="post" action="/e/search/index.php">
GET方式:/e/search/?searchget=1 /e/search/?searchget=1&keyboard=帝国&show=title
keyboard 搜索关键字变量 <input name="keyboard" type="text">
show 搜索字段变量(多个字段用","隔开。搜索字段必须是后台系统模型开启搜索项的字段) <input type="hidden" name="show" value="title,newstext">
classid 搜索栏目ID(不设置为不限,多个栏目可用","隔开,设置父栏目会搜索所有子栏目)

 

<input type="hidden" name="classid" value="1">
ztid 搜索专题ID(不设置为不限,多个专题可用","隔开) <input type="hidden" name="ztid" value="1">
tbname 按数据表搜索(需与搜索模板ID结合)

按表时,搜索自定义字段一定要注意搜索模板选择的所属系统模型是否对应。

<input type="hidden" name="tbname" value="news">
tempid 所用搜索模板ID(一般跟按表搜索结合使用)

 

<input type="hidden" name="tempid" value="1">
starttime与endtime 分别为搜索发布起始时间与结束时间的信息(不填为不限.格式:2008-02-27) <input name="starttime" type="text" value="0000-00-00" size="12">

<input name="endtime" type="text" value="0000-00-00" size="12">

startprice与endprice 分别为商品价格的起始价格与结束价格(price字段,不填为不限) <input name="startprice" type="text" value="0" size="6">

<input name="endprice" type="text" value="0" size="6">

搜索特殊字段 id: 按信息ID搜索

keyboard: 按关键字搜索(可实现按tags列出信息)

userid: 按发布者用户ID搜索

username: 按发布者用户名搜索

<input type="hidden" name="show" value="keyboard">
member 值为0则不限制

值为1则为只搜索会员投稿的信息

值为2则为只搜索管理员增加的信息

<input type="hidden" name="member" value="1">
orderby 排序字段:

可指定搜索结果页面的排序字段名。不指定为按发布时间(newstime)排序。排序字段必须是后台系统模型开启排序项的字段。

 

<input type="hidden" name="orderby" value="id">
myorder 排序方式:

0:倒序排列(默认)

1:顺序排列

<input type="hidden" name="myorder" value="1">
andor 设置多条件查询之间关联关系,有两种:

or : 或者的关系(默认)

and : 并且的关系

<input type="hidden" name="andor" value="and">
hh 逻辑运算联结符变量:

LT : 小于

GT : 大于

EQ : 等于

LE : 小于等于

GE : 大于等于

NE : 不等于

IN : 包含(搜索关键字用空格隔开每个值)

BT : 范围,两个值之间(搜索关键字用空格隔开两个值)

LK : 模糊查询(默认)

<input type="hidden" name="hh" value="LK">

 

 

单条件搜索的表单制作范例

一、表单范例1:

1、用Dreamweaver制作好表单:

设计视图:

代码模式下的表单代码

 

<tablewidth="320"border="0"cellspacing="1"cellpadding="3"><formname="searchform"method="post"action="/e/search/index.php"><tr><td>关键字:<inputname="keyboard"type="text"size="10"></td><td>范围:<selectname="show"><optionvalue="title">标题</option><optionvalue="smalltext">简介</option><optionvalue="newstext">内容</option><optionvalue="writer">作者</option><optionvalue="title,smalltext,newstext,writer">搜索全部</option></select></td></tr><tr><td>栏 目:<selectname="classid"><optionvalue="0">搜索全部</option><optionvalue="1">新闻中心</option><optionvalue="4">技术文档</option><optionvalue="22">下载中心</option></select></td><td><inputtype="submit"name="submit"value="搜索"></td></tr></form></table>

2、最终搜索表单显示效果为下图:

搜索表单多条件并列搜索的语法说明

多字段、多逻辑运算联结符并列搜索

(一)、多字段并列搜索:有“字符串”与“数组”两种传递方式

1、字符串传递为例子:

<inputtype="hidden"name="hh"value="LK"><inputtype="hidden"name="show"value="title,writer"><inputtype="hidden"name="keyboard"value="标题,作者">

(说明:上面为模糊查询title字段包含“标题”字符或者writer字段包含“作者”的信息)

 

2、数组传递为例子:

<inputtype="hidden"name="hh"value="LK"><inputtype="hidden"name="show[]"value="title"><inputtype="hidden"name="keyboard[]"value="标题"><inputtype="hidden"name="show[]"value="writer"><inputtype="hidden"name="keyboard[]"value="作者">

(说明:上面为模糊查询title字段包含“标题”字符或者writer字段包含“作者”的信息)

 

(二)、多逻辑运算联结符并列搜索

1、字符串传递为例子:

<inputtype="hidden"name="hh"value="LK,EQ"><inputtype="hidden"name="show"value="title,writer"><inputtype="hidden"name="keyboard"value="标题,作者">

(说明:上面为模糊查询title字段包含“标题”字符或者writer字段等于“作者”的信息)

 

2、字符串传递为例子:

<inputtype="hidden"name="show[]"value="title"><inputtype="hidden"name="hh[]"value="LK"><inputtype="hidden"name="keyboard[]"value="标题"><inputtype="hidden"name="show[]"value="writer"><inputtype="hidden"name="hh[]"value="EQ"><inputtype="hidden"name="keyboard[]"value="作者">

(说明:上面为模糊查询title字段包含“标题”字符或者writer字段等于“作者”的信息)

 

多条件并列搜索的表单制作范例

二、表单范例2:实现按标题、作者、录入者与信息ID同时搜索的表单

1、用Dreamweaver制作好表单:

设计视图:

代码模式下的表单代码

上面例子html代码

 

<formname="searchform"method="post"action="/e/search/index.php"><tablewidth="550"border="0"align="center"cellpadding="3"cellspacing="1"class="tableborder"><inputtype="hidden"name="tbname"value="news"><inputtype="hidden"name="tempid"value="1"><inputtype="hidden"name="andor"value="and"><trclass="header"><tdcolspan="2">新闻搜索</td></tr><trbgcolor="#FFFFFF"><tdwidth="97">标题:</td><tdwidth="388"><inputtype="hidden"name="show[]"value="title"><inputtype="hidden"name="hh[]"value="LK"><inputname="keyboard[]"type="text"></td></tr><trbgcolor="#FFFFFF"><td>作者:</td><td><inputtype="hidden"name="show[]"value="writer"><inputtype="hidden"name="hh[]"value="LK"><inputname="keyboard[]"type="text"></td></tr><trbgcolor="#FFFFFF"><td>录入者:</td><td><inputtype="hidden"name="show[]"value="username"><inputtype="hidden"name="hh[]"value="EQ"><inputname="keyboard[]"type="text"></td></tr><trbgcolor="#FFFFFF"><td>信息ID范围:</td><td><inputtype="hidden"name="show[]"value="id"><inputtype="hidden"name="hh[]"value="BT"><inputname="keyboard[]"type="text"><fontcolor="#666666">(例:“16”表示1到6之间)</font></td></tr><trbgcolor="#FFFFFF"><td>&nbsp;</td><td><inputtype="submit"name="Submit"value="马上搜索"><fontcolor="#666666">(不设置为不限)</font></td></tr></table></form>