多条件查询搜索页面,提交到当前页面处理

<?php
include("../DB.class.php");
$db = new DB();
/*var_dump($_POST["qy"]); //选择的区域
var_dump($_POST["zllx"]); //选择的租赁类型
var_dump($_POST["fwlx"]); //选择的房屋类型
var_dump($_POST["guanjianzi"]);*/ //输入的关键字
//$sql= "select * from House where Area in('坂井','三义庙','上上城')";所以需要将数组拆分成字符串,中间用 ',' 分隔,就用到implode("分隔符",数组)
$vg = "";
$tj1 = "1=1";
$tj2 = "1=1";
$tj3 = "1=1";
$tj4 = "1=1";
//判断传递值是否为空,四个条件判断四次
if(!empty($_POST["qy"]))
{
$attr = $_POST["qy"];
$str = implode("','",$attr); //将数组拆分成字符串,中间用 ',' 分隔
var_dump($str);
$tj1= " Area in ('{$str}')"; //两头的引号用查询语句中的引号补全 }
if(!empty($_POST["zllx"]))
{
$attr = $_POST["zllx"];
$str = implode("','",$attr);
$tj2= " RentType in ('{$str}')"; }
if(!empty($_POST["fwlx"]))
{
$attr = $_POST["fwlx"];
$str = implode("','",$attr);
$tj3= " HouseType in ('{$str}')"; } if(!empty($_POST["key"]))
{
$gjz = $_POST["key"];
$tj4= " KeyWord like '%{$gjz}%'";
$vg = $gjz;
}
$ss = " where {$tj1} and {$tj2} and {$tj3} and {$tj4}";
?>
<!--表单内容-->
<form action="zufang.php" method="post">
<div>区域:
<input type="checkbox" onclick="CheckAll(this,'qy')"/> 全选 <!--this代表按钮本身 qy代表下面选项的classname-->
</div>
<div>
    <?php
//区域选项
$sqlqy = "select distinct Area from house";
$attrqy = $db->Query($sqlqy,0,"housedb");
//var_dump($attr);
foreach($attrqy as $v)
{
echo "<input type='checkbox' value='{$v[0]}' class='qy' name='qy[]'>{$v[0]} ";
}
?>
</div><br /> <div>租赁类型:
<input type="checkbox" onclick="CheckAll(this,'zllx')"/> 全选
</div>
<div>
<?php
//租赁类型选项
$sqlzl = "select distinct RentType from house";
$attrzl= $db->Query($sqlzl,0,"housedb");
//var_dump($attrlx);
foreach($attrzl as $v)
{
echo "<input type='checkbox' value='{$v[0]}' class='zllx' name='zllx[]'/> {$v[0]}";
}
?>
</div><br /> <div>房屋类型:
<input type="checkbox" id="fwlxqx" onclick="CheckAll(this,'fwlx')"/> 全选
</div>
<div>
<?php
//房屋类型选项
$sqlfw = "select distinct HouseType from House";
$attrfw = $db->Query($sqlfw,0,"housedb");
//var_dump($attrfw);
foreach($attrfw as $v)
{
echo "<input type='checkbox' value='{$v[0]}' class='fwlx' name='fwlx[]'/> {$v[0]}";
}?>
</div><br />
 <!--关键字搜索框-->
<div>关键字:
<input type="text" name="key" value="<?php echo $vg;?>" />
</div>
<br />
<input type="submit" value="搜索" />
</form><br /> <!--房屋租赁表-->
<table width="100%" border="1" cellpadding="0" cellspacing="0">
<tr><td>关键字</td><td>区域</td><td>建筑面积</td><td>租金</td><td>租赁类型</td><td>房屋类型</td></tr>
<?php
$sqlss = "select * from House ".$ss;
//echo $sqlss;
$attrss = $db->Query($sqlss,0,"housedb");
foreach($attrss as $v)
{ $rpg = "<span style='color:red'>{$vg}</span>";
$strg = str_replace($vg,$rpg,$v[1]);
echo "<tr> <td>{$strg}</td>
<td>{$v[2]}</td>
<td>{$v[3]}</td>
<td>{$v[4]}</td>
<td>{$v[5]}</td>
<td>{$v[6]}</td>
</tr>";
}
?>
</table>
</body>
<script type="text/javascript">
function CheckAll(a,b)
{
var xz = a.checked; //找到全选按钮的选中状态
var ck = document.getElementsByClassName(b); //找到全选相对应的checkbox
for(var i=0; i<ck.length;i++)
{
ck[i].checked = xz;
}
}
</script>

注意:

1.多个全选按钮用一个方法实现相同功能,就需要传递参数给方法

上文中就传了两个参数,this和classname

this代表元素本身,classname代表各个全选所对应的选项

2.将数组拼接成字符串用implode("分隔符",数组)

将字符串拆分成数组用explode("分隔符","字符串")

分隔符要写好,可以写个例子看清楚再写

php......房屋租赁练习的更多相关文章

  1. 【租房合同】2017北京市房屋租赁合同(自行成交版).doc

    最近在北京租房,找租房合同 这个文档还是比较新的,在百度文库上需要积分下载的文档,现在共享给大家吧. 下载地址: https://pan.baidu.com/s/1cEh7lhBqQgkJhB32Df ...

  2. php 之 房屋租赁练习(0509)

    做出以下页面并实现其对应的功能: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...

  3. C#事件

    事件(event),这个词儿对于初学者来说,往往总是显得有些神秘,不易弄懂.而这些东西却往往又是编程中常用且非常重要的东西.大家都知道windows消息处理机制的重要,其实C#事件就是基于window ...

  4. 2013年9月份第2周51Aspx源码发布详情

    休闲农庄企业站源码  2013-9-13 [VS2008]功能介绍:  首页功能:关于我们 资讯中心 休闲娱乐 餐饮娱乐 环境展示 园林展示 交通指引 联系我们  后台功能:      基本信息:服务 ...

  5. C#事件(event)解析

    事件(event),这个词儿对于初学者来说,往往总是显得有些神秘,不易弄懂.而这些东西却往往又是编程中常用且非常重要的东西.大家都知道windows消息处理机制的重要,其实C#事件就是基于window ...

  6. 6.24 AppCan移动开发者大会,我爱我家即将闪亮登场!

    6.24 AppCan移动开发者大会进入倒计时,报名通道即将关闭! “6月24日, 2016AppCan移动开发者大会即将召开,以“平台之上,应用无限”为主题,1500位行业精英汇聚在此,重磅新品发布 ...

  7. C#事件解析

    事件(event),这个词儿对于初学者来说,往往总是显得有些神秘,不易弄懂.而这些东西却往往又是编程中常用且非常重要的东西.大家都知道windows消息处理机制的重要,其实C#事件就是基于window ...

  8. 尚学堂JavaEE项目备选

    偶然得知:记下待练 微博 软件人才网 论坛 博客系统 京东网上商城 赶集网 拉手网 优酷视频 百度知道(问答) 生产管理系统 房屋租赁网 金融股票

  9. 你可能把A/B测试做错了

    大卫奥格威说过,"永远不要停止试验,你的广告也就永远不会停止改进". 在当今的网络世界中,类似于吆喝科技 AppAdhoc A/B Testing 这样的工具越来越多,AB测试和转 ...

随机推荐

  1. js 导入json配置文件

    import AA from './menu.json' console.log(AA) 匹配好路径

  2. BaseAdapter的使用(笔记)

    适配器模式的应用: 1.减少程序耦合性 2.easy扩展 BaseAdapter ListView的显示与缓存机制:须要才显示,显示完就被会受到缓存. BaseAdapter基本结构 --public ...

  3. 基于RxJava2+Retrofit2精心打造的Android基础框架

    代码地址如下:http://www.demodashi.com/demo/12132.html XSnow 基于RxJava2+Retrofit2精心打造的Android基础框架,包含网络.上传.下载 ...

  4. HTML5实战与剖析之媒体元素(6、视频实例)

    HTML5中的视频标签和及其模仿视频播放器的效果在一些手机端应用比較多.由于手机端基本上废除了flash的独断.让HTML5当家做主人,所以对视频支持的比較好. 所以今天专门为大家奉上HTML5视频标 ...

  5. 使用svn 在 github上下载单个文件夹?

    事实上可以用svn checkout 下来的.(但就是速度不知道为啥那么慢) 第一步:输入你的仓库地址 第二步:选择thunk,然后仓库的内容尽收眼底.接下来就可以选择你想下载的任意文件夹了. (如果 ...

  6. bzoj 2458: [BeiJing2011]最小三角形 题解

    [前言]话说好久没有写题解了.到暑假了反而忙.o(╯□╰)o [原题] 2458: [BeiJing2011]最小三角形 Time Limit: 10 Sec  Memory Limit: 128 M ...

  7. stage3D基础五-----Working with 3D cameras(转)

    原文地址:http://www.adobe.com/cn/devnet/flashplayer/articles/3d-cameras.html 原文是英文的,这里就不贴了,内容主要介绍直接使用相机坐 ...

  8. Quartz.Net - Lesson 1: 使用Quartz

    Lesson 1: 使用Quartz 本系列文章是官方3.x文档的翻译,原文地址:https://www.quartz-scheduler.net/documentation/quartz-3.x/t ...

  9. bzoj3531【SDOI2014】旅行

    3531: [Sdoi2014]旅行 Time Limit: 20 Sec  Memory Limit: 512 MB Submit: 850  Solved: 433 [Submit][Status ...

  10. 成长这事儿,不可不说-------Day36

    事实上我一直都有一个观点,从我当年刚学抛物线那会就有:人生事实上就是一条轨迹,无非是一些点的集合.只是有些在低谷,有些在高峰,放形象了看,有些熠熠生辉,有些暗淡的几若消逝,有些人总喜欢回头数着过往的痕 ...