我正在修改别人的代码,并且遇到了一个我似乎无法解决的问题。在数据库中,我们有商店位置和五种类型的产品。如果某个地点销售产品,则数据库值为“X”。如果不是,则数据库值为空。我正在修改的应用程序有一个搜索框,一个城市,zip和五个产品的复选框(这是刚刚添加的部分)。理想情况下,您只能输入一个参数,它会根据你输入/检查了什么,或者你可以输入/检查多个参数。城市/邮编位工作正常,但结果只显示销售全部5种产品的地点 - 它不识别空值。这是我的提交功能的搜索形式:多个复选框值
<script type="text/javascript">
$(function() {
$(".form #searchBtn").click(function() {
var searchParameters = "";
if ($(".form #city").val() != "") {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "city=" + $(".form #city").val();
}
if ($(".form #zip").val() != "") {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "zip=" + $(".form #zip").val();
}
if ($(".form #product1").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product1=" + "X";
}
if ($(".form #product2").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product2=" + "X";
}
if ($(".form #product3").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product3=" + "X";
}
if ($(".form #product4").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product4=" + "X";
}
if ($(".form #product5").is(':checked')) {
if (searchParameters != "") {
searchParameters += "&";
}
searchParameters += "product5=" + "X";
}
searchParameters = searchParameters.replace(" ","%20");
$.fn.colorbox({ href: 'locations.aspx?' + searchParameters });
});
});
</script>
此代码生成一个URL与搜索参数,locations.aspx城市=胡说& otherParamsHere?任何想法将不胜感激。
编辑
要回答你的问题,代码全都在前端。以下是查询生成结果的locations.aspx的查询内容。
<asp:SqlDataSource ID="locations" runat="server"
SelectCommand="SELECT * FROM [locations] WHERE (([city] LIKE '%' + @city + '%') AND ([zip] LIKE '%' + @zip + '%') AND ([product1] LIKE '%' + @product1 + '%') AND ([product2] LIKE '%' + @product2 + '%') AND ([product3] LIKE '%' + @product3 + '%') AND ([product4] LIKE '%' + @product4 + '%') AND ([product5] LIKE '%' + @product5 + '%')) ORDER BY [retailer_name]">
<SelectParameters>
<asp:QueryStringParameter DefaultValue="%" Name="city"
QueryStringField="city" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="zip"
QueryStringField="zip" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product1"
QueryStringField="product1" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product2"
QueryStringField="product2" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product3"
QueryStringField="product3" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product4"
QueryStringField="product4" Type="String" />
<asp:QueryStringParameter DefaultValue="%" Name="product5"
QueryStringField="product5" Type="String" />
</SelectParameters>
</asp:SqlDataSource>
编辑
再次修订包括形式。
<input type="text" id="city" size="20" />
<input type="text" id="zip" maxlength="5" size="5" />
<input type="checkbox" id="product1" value="" />
<input type="checkbox" id="product2" value="" />
<input type="checkbox" id="product3" value="" />
<input type="checkbox" id="product4" value="" />
<input type="checkbox" id="product5" value="" />
<input type="button" value="Search" id="searchBtn"/>
可能是您的后端代码位于locations.aspx.cs中。你可以追加一些包含搜索方法的代码吗? –
见上面...让我知道如果有什么我可以告诉你。 – user2697262
请参阅我的建议以获取下面的新Sql语句。 –