日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

ASP.NET MVC獲取多級類別組合下的產品

瀏覽:452日期:2022-06-08 10:34:05

本篇是針對我在做項目過程中遇到的特定需求而做的一個Demo, 沒有很大的通用性,讀者酌情可繞行。

標題不能完全表達本意,確切的情景需要展開說。假設有三級分類,關于分類這樣設計:

    public class Category
    {
public int Id { get; set; }
public string Name { get; set; }
public int ParentId { get; set; }
    }

然后產品可以屬于多個分類,以下的Categories屬性值是以英文逗號隔開、由分類編號拼接而成的字符串。

    public class Product
    {
public int Id { get; set; }
public string Name { get; set; }
public string Categories { get; set; }
    }

由于種種原因,Categories屬性值只是存儲了由第三級分類編號拼接而成的字符串。

在前端,需要把分類作為查詢條件來查詢產品,可能只選擇一級分類,把一個數字字符串(比如"1")發送給服務端;可能同時選擇一級和二級分類,也把一個數字字符串(比如"1,2")發送給服務端;當然,也有可能同時選擇一級、二級和三級分類作為查詢條件(比如"1,2,3")。換句話說,如果諸如"1"或"1,2"或"1,2,3"這樣的查詢條件轉換成數組后,如果數組的每一個元素都被包含在Product的Categories屬性值轉換成的數組中,那這個產品就符合搜索條件。

簡單來說,是這樣:假設搜索條件是"1,2",Product的Categories屬性值為"1,3,2,5",我們不是判斷"1,2"這個字符串是否包含在"1,3,2,5"字符串中,而是把"1,2"先split成數組,叫做array1, 把"1,3,2,5"也split成數組,叫做array2,最后判斷array1的每個元素是否都被包含在array2中。

還有一個問題需要解決:當前的Product的Categories屬性值只存儲了所有第三級分類編號拼接成的字符串,而前端輸入的搜索條件可能會包含一級分類或二級分類等,所以,我們需要把Product轉換一下,希望有一個類的某個屬性值能存儲由一級、二級、三級分類拼接而成的字符串。

    public class ProductWithThreeCate
    {
public int Id { get; set; }
public string Name { get; set; }
public string AllCategoreis { get; set; }
    }

以上, AllCategoreis屬性值就用來存儲由一級、二級、三級分類拼接而成的字符串。

有一個方法獲取所有分類:

static List<Category> GetCategories()
{
    return new List<Category>()
    {
new Category(){Id = 1, Name = "根", ParentId = -1},
new Category(){Id = 2, Name = "一級分類1",ParentId = 1},
new Category(){Id = 3, Name = "一級分類2", ParentId = 1},
new Category(){Id = 4, Name = "二級分類11",ParentId = 2},
new Category(){Id = 5, Name = "二級分類12",ParentId = 2},
new Category(){Id = 6, Name = "二級分類21",ParentId = 3},
new Category(){Id = 7, Name = "二級分類22",ParentId = 3},
new Category(){Id = 8, Name = "三級分類111",ParentId = 4},
new Category(){Id = 9, Name = "三級分類112",ParentId = 4},
new Category(){Id = 10, Name = "三級分類121",ParentId = 5},
new Category(){Id = 11, Name = "三級分類122",ParentId = 5},
new Category(){Id = 12, Name = "三級分類211",ParentId = 6},
new Category(){Id = 13, Name = "三級分類212",ParentId = 6},
new Category(){Id = 14, Name = "三級分類221",ParentId = 7}
    };
}

有一個方法獲取所有產品:

static List<Product> GetProducts()
{
    return new List<Product>()
    {
new Product(){Id = 1, Name = "產品1",Categories = "10,12"},
new Product(){Id = 2, Name = "產品2", Categories = "12,13"},
new Product(){Id = 3, Name = "產品3",Categories = "10,11,12"},
new Product(){Id = 4, Name = "產品4",Categories = "13,14"},
new Product(){Id = 5, Name = "產品5",Categories = "11,13,14"}
    };
}

接下來的方法是根據搜索條件(比如是"1,2")來查找滿足條件的ProductWithThreeCate集合,如下:

/// <summary>
/// 獲取滿足某些條件的集合
/// </summary>
/// <param name="query">以英文逗號隔開的字符串,比如:2,5</param>
/// <returns></returns>
static List<ProductWithThreeCate> GetResultByQuery(string query)
{
    //最終結果
    List<ProductWithThreeCate> result = new List<ProductWithThreeCate>();
    //臨時結果 此時ProductWithThreeCat的屬性AllCategoreis包含所有一級、二級、三級分類ID拼接成的字符串
    List<ProductWithThreeCate> tempResult = new List<ProductWithThreeCate>();
    //獲取所有的產品
    List<Product> allProducts = GetProducts();
    //遍歷這些產品
    foreach (var item in allProducts)
    {
ProductWithThreeCate productWithThreeCate = new ProductWithThreeCate();
productWithThreeCate.Id = item.Id;
productWithThreeCate.Name = item.Name;
//所有一級、二級、三級拼接成以英文逗號隔開的字符串
string temp = string.Empty;
//當前產品只包含三級拼接成的、也是以英文隔開的字符串,split成數組
string[] theThirdCates = item.Categories.Split(",");
//遍歷這些三級數組
foreach (string i in theThirdCates)
{
    //三級類別轉換成整型
    int theThirdInt = int.Parse(i);
    //獲取三級類別
    Category theThirdCate = GetCategories().Where(c => c.Id == theThirdInt).FirstOrDefault();
    //獲取二級類別
    Category theSecondCate = GetCategories().Where(c => c.Id == theThirdCate.ParentId).FirstOrDefault();
    //獲取一級類別
    Category theFirstCate = GetCategories().Where(c => c.Id == theSecondCate.ParentId).FirstOrDefault();
    temp += i + "," + theSecondCate.Id.ToString() + "," + theFirstCate.Id.ToString() + ",";
}
//去掉最后一個英文逗號
temp = temp.Substring(0, temp.Length - 1);
//轉換成集合,去除重復項,比如不同的三級可能有相同的一級或二級父類
IEnumerable<string> tempArray = temp.Split(",").AsEnumerable().Distinct();
//所有一級、二級、三級拼接成以英文逗號隔開的字符串,但已經去除了重復的一級和二級
string tempagain = string.Empty;
//再次遍歷集合拼接成字符串
foreach (var s in tempArray)
{
    tempagain += s + ",";
}
productWithThreeCate.AllCategoreis = tempagain.Substring(0, tempagain.Length - 1);
tempResult.Add(productWithThreeCate);
    }
    //遍歷臨時結果
    foreach (var item in tempResult)
    {
//把當前包含一級、二級、三級的,以英文逗號隔開的字符串split成數組
string[] itemArray = item.AllCategoreis.Split(",");
//把當前查詢字符串split成數組
string[] queryArray = query.Split(",");
//如果queryArray的每一個元素都被包含在itemArray中,那就保存起來
if (queryArray.All(x => itemArray.Contains(x)) == true)
{
    result.Add(item);
}
    }
    return result;
}

客戶端的調用如下:

    List<ProductWithThreeCate> result = GetResultByQuery("2,5");
    //遍歷最終的結果
    foreach (var item in result)
    {
Console.WriteLine(item.Name+ "  " + item.AllCategoreis);
    }
    Console.ReadKey(); 

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對的支持。如果你想了解更多相關內容請查看下面相關鏈接

標簽: ASP.NET
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲一区二区三区久久久| 久久婷婷激情| 久久精品卡一| 亚洲精品国产偷自在线观看| 亚洲欧美日本国产| 成人久久久久| 精品一区视频| aa亚洲婷婷| 国产精品最新| 日韩欧美2区| 日韩中文字幕1| 久久久久久久久丰满| 精品国产黄a∨片高清在线| 日韩精品一二区| 在线日韩av| 精品亚洲美女网站| 精品美女视频 | 1024精品久久久久久久久| 美女精品一区二区| 日本午夜精品久久久久| 亚洲资源网站| 国产视频一区免费看| 日本vs亚洲vs韩国一区三区二区| 亚洲三级毛片| 免费成人性网站| 视频一区二区三区在线| 蜜桃国内精品久久久久软件9| 99久久婷婷这里只有精品| 青青草视频一区| 国产精品毛片在线| 亚洲性视频h| 欧美 日韩 国产一区二区在线视频 | 国产一区丝袜| 精品亚洲免a| 91精品国产自产观看在线| 天堂va欧美ⅴa亚洲va一国产| 夜夜精品视频| 中文精品在线| 激情综合自拍| 免费观看在线综合| 色偷偷色偷偷色偷偷在线视频| 97精品一区| 日韩久久精品| 国产精品99一区二区| 欧美亚洲国产精品久久| 国产精品yjizz视频网| 婷婷成人av| 欧美另类中文字幕| 国产精品一区二区三区美女| 国产九一精品| 女生影院久久| 久久精品理论片| 神马久久午夜| 日韩精品麻豆| 视频在线在亚洲| 国产精品一线天粉嫩av| 日韩中文av| 精品一区不卡| 米奇777超碰欧美日韩亚洲| 麻豆成人在线| 伊人久久成人| 久久影视三级福利片| 国产网站在线| 国产精品777777在线播放| 日本久久一区| 麻豆理论在线观看| 麻豆亚洲精品| 久久中文字幕一区二区三区| 麻豆一区二区三| 欧美精品成人| 亚洲一区二区三区高清| 麻豆国产精品777777在线| 欧美va亚洲va日韩∨a综合色| 日韩福利在线观看| 免费一级欧美片在线观看网站| 中文字幕成在线观看| 麻豆精品91| 日本不卡在线视频| 久久一区二区三区电影| 欧美日韩调教| 国精品一区二区| 久久影视三级福利片| 国产成人精品一区二区免费看京 | 色88888久久久久久影院| 九九九精品视频| 婷婷久久一区| 国产欧美一区| 久久精品一区二区三区中文字幕| 夜夜嗨av一区二区三区网站四季av| 国产精品一区二区三区www| 精品九九在线| 欧美成a人免费观看久久| 在线亚洲激情| 午夜在线一区二区| 日韩av不卡一区二区| 日韩在线视频精品| 日本不卡一区二区| 婷婷精品进入| 欧美日韩国产高清电影| 在线 亚洲欧美在线综合一区| 国产精品主播| 久热精品在线| 成人午夜国产| 国产视频网站一区二区三区| 老司机免费视频一区二区| 亚州欧美在线| 亚洲电影在线一区二区三区| 国产精品日韩| 福利片在线一区二区| 视频一区中文字幕精品| 亚洲男女自偷自拍| 日本不卡一区二区三区| 9色国产精品| 日韩精品欧美| 亚洲精品免费观看| 国产精品igao视频网网址不卡日韩 | 免费观看久久av| 日韩视频1区| 精品亚洲成人| 国产精品.xx视频.xxtv| 日韩高清欧美激情| 亚洲精品免费观看| 国产精品亚洲成在人线| 日韩中文一区二区| 亚洲日本久久| 九九久久国产| 中文字幕免费一区二区| 日韩中文字幕| 黄色亚洲在线| 国产韩日影视精品| 亚洲大片在线| 欧美a级片一区| 91精品啪在线观看国产18| 国产日韩中文在线中文字幕 | 日本aⅴ精品一区二区三区| 国产不卡av一区二区| 亚洲精品四区| 日韩在线电影| 日韩av中文在线观看| 日韩精品一卡二卡三卡四卡无卡| 精品视频91| 国产经典一区| 精品国产三区在线| 四虎成人av| 久久高清免费| 蜜桃免费网站一区二区三区| 久久午夜视频| 日韩av中文在线观看| 亚洲ww精品| 韩日一区二区| 久久久久91| 久久xxxx| 欧美极品中文字幕| 国产丝袜一区| 久久精品国产在热久久| 国产在线一区不卡| 国产日韩一区二区三区在线| 国产精品高颜值在线观看| 国产麻豆久久| 亚洲少妇在线| 亚洲69av| 欧美男人天堂| 日韩在线中文| 亚洲作爱视频| 欧美 日韩 国产一区二区在线视频 | 久久丁香四色| 国产乱码精品一区二区三区四区| 国产一区二区三区亚洲| 精品久久久久中文字幕小说| 一区在线观看| 国产亚洲观看| 蜜臀国产一区| 国产+成+人+亚洲欧洲在线| 精品网站999| 亚洲色诱最新| 久久伊人国产| 午夜在线观看免费一区| 久久激情综合网| 久久精品97| 久久久久国产精品一区三寸| 中文字幕免费精品| 日韩精品午夜视频| 亚洲深深色噜噜狠狠爱网站 | 日韩精品免费观看视频| 欧美激情日韩| 91偷拍一区二区三区精品| 激情久久久久久| 日韩高清在线不卡| 久久国产尿小便嘘嘘| aa亚洲婷婷| 成人日韩在线| 久久国产日本精品| 国产丝袜一区| 毛片在线网站| 久久精品高清| 蜜臀91精品一区二区三区| 日韩激情一二三区| 精品国产一区二区三区噜噜噜| 日韩网站中文字幕| 日韩午夜av在线|