我有一个名为Career Item
的文档类型,其中包含一些属性和2个内容选择器。一个是选择一种职业:例如。司机,另一个是选择职业分支的分支:例如。根特比利时。
我的职业类型和分支位于单独的Content repository
中,这意味着它们没有模板,它只是一个包含可在多个内容页面上使用的属性的文档。
我为此创建了2个过滤器,并使用一些jQuery我设法根据选择设置url以获取网址:
http://localhost:59733/nl/vacatures/?f=1075&f=1076&b=1085&b=1082
您的f
包含Career type
ID,b
包含Branch
ID。
现在在我的剃刀中,我正在根据选择对内容节点进行过滤,但它非常混乱。
// Collect values for branch and function from the url querystring to perform filtering
var branch = umbraco.library.RequestQueryString("b"); // eg: 1085,1082 from example url above
var function = umbraco.library.RequestQueryString("f"); // eg: 1075,1076 from example url above
// Take the careers list content node
var careersList = Umbraco.TypedContentAtRoot().DescendantsOrSelf("CareersList").FirstOrDefault();
var careerItems = careersList.Children.Where("Visible");
string query = "";
string funcQuery = "";
string branchQuery = "";
// Filter on fuction
if (!String.IsNullOrEmpty(function))
{
// Property alias function: content picker
string[] functions = function.Split(',');
foreach (string func in functions)
{
if (!String.IsNullOrEmpty(funcQuery))
{
funcQuery += " || function == \"" + func + "\"";
}
else
{
funcQuery = "function == \"" + func + "\"";
}
}
}
// Filter on branch
if (!String.IsNullOrEmpty(branch))
{
// Property alias branch: content picker
string[] branches = branch.Split(',');
foreach (string br in branches)
{
if (!String.IsNullOrEmpty(branchQuery))
{
branchQuery += " || branch == \"" + br + "\"";
}
else
{
branchQuery = "branch == \"" + br + "\"";
}
}
}
funcQuery = !String.IsNullOrEmpty(funcQuery) ? "(" + funcQuery + ")" : "";
branchQuery = !String.IsNullOrEmpty(branchQuery) ? "(" + branchQuery + ")" : "";
query = funcQuery + (!String.IsNullOrEmpty(branchQuery) ? " && " + branchQuery : "");
if (!String.IsNullOrEmpty(query))
{
careerItems = careerItems.Where(query);
}
我在这里遗漏了什么,可以简化一下吗?因为现在它只有2个过滤器,但如果我有5个或6个过滤器,那么这是不可行的......
/迈克尔
答案 0 :(得分:1)
您可以使用以下内容:
var branch = "1085,1082";
var function = "1075,1076";
var careerTypes =
careersList
.Where(c => c.IsVisible()
&&
branch.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries)
.Select(i => int.Parse(i))
.Contains(c.GetPropertyValue<int>("branchId"))
&&
branch.Split(new[] { ',' }, StringSplitOptions.RemoveEmptyEntries)
.Select(b => int.Parse(b))
.Contains(c.GetPropertyValue<int>("functionId"))
);
//branchId and functionId are the property names of those 2 content pickers
答案 1 :(得分:1)
我也可以考虑把它全部放在IPublishedContent的扩展方法中,称为CheckFilters,它接受数组作为参数,所以你可以这样做:
var branches = Request.QueryString("b").Split(",".ToCharArray(), StringSplitOptions.RemoveEmptyEntries);
var functions= Request.QueryString("f").Split(",".ToCharArray(), StringSplitOptions.RemoveEmptyEntries);
var careerTypes = careersList.Where(a => a.IsVisible() && a.CheckFilters(branches, functions));
您可以使用扩展方法中的所有逻辑,然后可以轻松添加其他过滤器,因为您只需修改扩展方法,或添加ne重载。
您也不需要使用umbraco.library.RequestQueryString,因为它只是Request.QueryString函数的包装器。
这是扩展方法的一个非常粗略的例子:
public static bool CheckFilters(this IPublishedContent content, string[] branches, string[] functions)
{
return branches.Contains(content.GetPropertyValue<string>("branchPropertyAlias", "")) && functions.Contains(content.GetPropertyValue<string>("functionPropertyAlias", ""));
}
这是一个非常简单的例子,假设内容项只有一个分支和一个函数。