|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
在学习PHP这六个月里,每看到一个优秀的php脚本,就会兴奋的手舞足蹈,嘴里还不停的说:太酷了,太酷了。呵呵,很幼稚吧,但这可能就是兴趣。 帝国CMS供应了对照壮大的搜刮了局挪用,你可以依照帝国cms搜刮表单制造语法,制造出知足你需求的大局部搜刮功效。假如你在你的数据库中有自界说字段,那末能够需求改一下e/search/index.php对form表单提交的数据处置,可以参考文章最初供应的例子。先来看看搜刮表单变量申明:
变量名申明例子搜刮表单提交地址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=titlekeyboard搜刮关头字变量<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分离为商品价钱的肇端价钱与停止价钱(不填为不限)<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排序字段:
0:按宣布日期(默许)
1:按ID
2:按评论数
3:按阅读人气
4:按下载数<input type="hidden" name="orderby" value="1">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">
上面是一个例子:
<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>
搜刮表单多前提并列搜刮语法申明
1. 多字段并列搜刮:有"字符串"与"数组"两种传递体例
字符串传递为例子:
<inputtype="hidden"name="hh"value="LK">
<inputtype="hidden"name="show"value="title,writer">
<inputtype="hidden"name="keyboard"value="题目,作者">
申明:下面为恍惚查询title字段包括"题目"字符或writer字段包括"作者"的信息
数组传递为例子:
<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字段包括"作者"的信息
2. 多逻辑运算联合符并列搜刮
字符串传递为例子:
<inputtype="hidden"name="hh"value="LK,EQ">
<inputtype="hidden"name="show"value="title,writer">
<inputtype="hidden"name="keyboard"value="题目,作者">
申明:下面为恍惚查询title字段包括"题目"字符或writer字段等于"作者"的信息
字符串传递为例子:
<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字段等于"作者"的信息。
一个实践例子
表单设计以下:
<formaction="[!--news.url--]e/search/index.php"method="post"name="searchform"id="searchform">
<selectname="classid"id=""style="display:none">
<optionvalue="59,60,78,79,80,81"selected>全体</option>
</select>
<inputtype="hidden"name="show"value="title,myarea,mycategory,smalltext"/>
<inputtype="hidden"name="tempid"value="1"/>
<tablewidth="100%"cellspacing="0"cellpadding="0"border="0">
<tbody>
<trclass="even">
<tdstyle=" text-align:left;">区域:
<selectname="area"id="">
<optionvalue="">不限</option>
<optionvalue="喷鼻洲">喷鼻洲</option>
<optionvalue="吉大">吉大</option>
<optionvalue="拱北">拱北</option>
<optionvalue="新喷鼻洲">新喷鼻洲</option>
<optionvalue="前山">前山</option>
<optionvalue="南屏">南屏</option>
<optionvalue="金湾">金湾</option>
<optionvalue="斗门">斗门</option>
</select>
房型:
<selectname="category"id="">
<optionvalue="">不限</option>
<optionvalue="58_0">一房</option>
<optionvalue="58_1">二房</option>
<optionvalue="58_2">三房以上</option>
<optionvalue="58_3">公寓</option>
<optionvalue="58_4">写字楼</option>
<optionvalue="58_5">商铺</option>
<optionvalue="58_6">厂房</option>
</select>
</td>
<td> </td>
</tr>
<trclass="even">
<tdstyle=" text-align:left;">工夫局限: <inputname="starttime"type="text"value="2008-08-08"size="12"onclick="calendar.show(this);"/> 到 <inputtype="text"id="todayButton"name="todayButton"value=""size="12"onclick="calendar.show(this);"/> (不选则不限时段)</td>
<td> </td>
</tr>
<trclass="even">
<tdstyle=" text-align:left;"><inputname="keyboard"type="text"size="32"value=""id="keyboard"class="inputText"/> <inputtype="submit"name="Submit22"value=" 搜 索 "/></td>
<td></td>
</tr>
</tbody>
</table>
</form>
为了可以到场对自界说字段myarea与mycategory的搜刮,咱们需求对e/search/index.php停止恰当改写:
$keyboard=$_POST['keyboard'].','.$_POST['area'].','.$_POST['category'];
// 这是本来的:$keyboard=$_POST['keyboard'];
$keyboardone=0;
if(is_array($keyboard))
{}
elseif(strstr($keyboard,','))
{
$keyboard=explode(',',$keyboard);
}
else
{
$keyboard=trim($keyboard);
$len=strlen($keyboard);
if($len<$public_r[min_keyboard]$len>$public_r[max_keyboard])
{
printerror("MinKeyboard",$getfrom,1);
}
$keyboardone=1;
}
在学习中,我也一直这样要求着自己。 |
|