我有列出我所有产品的数组列表。样本阵列:使用搜索表格过滤数组列表的数据
$products = array();
$products[] = array('name'=> 'Product 1','description' => 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.',
'location' => 'A city', 'type' => 'Type 1', 'status' => 'new', 'tags'=>'', 'page_url'=>'p1.html', 'image'=>'products/assets/images/1/prod-image.jpg');
$products[] = array('name'=> 'Product 2','description' => 'Donec eleifend quam neque, ut mollis massa aliquet id.',
'location' => 'B city', 'type' => 'Type 1', 'status' => 'under', 'tags'=>'show-homepage', 'page_url'=>'p2.html', 'image'=>'products/assets/images/2/prod-image.jpg');
$products[] = array('name'=> 'Product 3','description' => 'Nam non tristique mi.',
'location' => 'A city', 'type' => 'Type 3', 'status' => 'new', 'tags'=>'', 'page_url'=>'p3.html', 'image'=>'products/assets/images/3/prod-image.jpg');
$products[] = array('name'=> 'Product 4','description' => 'Vestibulum accumsan dolor id orci gravida viverra.',
'location' => 'C city', 'type' => 'Type 2', 'status' => 'new', 'tags'=>'', 'page_url'=>'p4.html', 'image'=>'products/assets/images/4/prod-image.jpg');
我想要实现的是显示使用搜索表单过滤的所有产品。类似于SQL查询条件WHERE location = $_GET['location'] AND type = $_GET['type'] AND status = $_GET['status']
。考虑的是,当选定的值是Any
(实施例的位置或状态=任何。)将过滤的产物仅type
不管位置和状态或反之亦然..
这是我的HTML形式:
<form name="search-form" method="GET">
<div class="searchform-title">Location</div>
<div style="margin-bottom:20px;">
<select name="location" style="width:100%; padding:5px">
<option value='Any' selected>Any</option>
<option value='A city'>A city</option>
<option value='B City'>B City</option>
<option value='C city'>C city</option>
<option value='D city'>D city</option>
<option value='L city'>L city</option>
<option value='M city'>M city</option>
<option value='T city'>T city</option>
</select>
</div>
<div class="searchform-title">Type</div>
<div style="margin-bottom:20px;">
<select name="type" style="width:100%; padding:5px">
<option value='Any' selected>Any</option>
<option value='Type 1'>Type 1</option>
<option value='Type 2'>Type 2</option>
<option value='Type 3'>Type 3</option>
<option value='Type 4'>Type 4</option>
</select>
</div>
<div class="searchform-title">Status</div>
<div style="margin-bottom:20px;">
<select name="status" style="width:100%; padding:5px">
<option value='Any' selected>Any</option>
<option value='New'>New</option>
<option value='Old'>Old</option>
<option value='Under'>Under</option>
</select>
</div>
<input class="proj-search-btn" type="submit" name="search" value="Search"/>
</form>
我到目前为止所尝试的是使用一个函数,但它只能得到产品的位置。 以下是示例功能代码。 See sample code
有没有更好的方法来使用搜索表单搜索数组列表中的项目?并有3个选定的值(查询)来搜索?
一种方法是使用以前的呼叫和新属性的结果,回想起自己的搜索功能。 –
@MasterDJon如何添加新的属性到第一个(s)过滤的数组? –
'$ productsFiltered = search($ products,'firstKey','firstValue'); $ productsFiltered = search($ productsFiltered,'secondKey','secondValue);' –