Mvc里查询商品页面
/// <summary>
/// 商品小类筛选页面 GoodsTypeName ----------------SelectGoods--商品筛选 --图文
/// Home/SelectGoods
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public ActionResult selectgoods(int id = , string pvlueIDs = null)
{
ViewBag.ReturnUrl = Request.Url;
#region -------------SelectGoods 商品筛选 --图文
if (id == )//商品小类ID为空
{
return HttpNotFound();
}
else //商品小类ID不为空
{
if (id != && pvlueIDs == null)//商品小类ID不等于0, 商品属性不为空
{
#region -------------首次请求
var vbv = from f in db.GoodsPropertys
where f.GoodsType.GoodsTypeID == id
orderby f.GoodsPropertyID
select f;
int sproCout = vbv.ToList().Count;
GoodsProperty[] sfArray = new GoodsProperty[sproCout];
for (int i = ; i < sproCout; i++)
{
sfArray[i] = new GoodsProperty();
sfArray[i].GoodsPropertyID = ;//盒子
}
GoodsType slg = db.GoodsTypes.Find(id);//转换
SKUtypebrandgoods sbg = new SKUtypebrandgoods();
sbg.SmallType = slg;//商品小类 #region -------------Linq
GoodsType middleType = db.GoodsTypes//商品中类
.Where(f => f.GoodsTypeID == id)
.Select(f => f.GoodsTypes)
.ToArray()[];
sbg.BigType = db.GoodsTypes//商品大类
.Where(f => f.GoodsTypeID == middleType.GoodsTypeID)
.Select(f => f.GoodsTypes)
.ToArray()[];
sbg.GoodsBrandLst = db.Goodss//商品品牌
.Where(f => f.GoodsTypeID == slg.GoodsTypeID)
.Select(f => f.GoodsBrand)
.Distinct()
.ToList();
sbg.GoodsProertyLst = db.GoodsPropertys//商品属性
.Where(f => f.GoodsType.GoodsTypeID == id)
.Select(f => f)
.ToList();
sbg.GoodsPropertyValueLst = db.GoodsPropertyValues.ToList();//所有商品属性值
sbg.Goodses = db.Goodss//商品
.Where(f => f.GoodsTypeID == id)
.Select(f => f)
.ToList();
#endregion
sbg.GproArray = sfArray;//商品属性数组 #region -------------取模分页
sbg.BrandID = ;
sbg.shelvesTimeArray = new string[];
sbg.shelvesTimeArray[] = "";//Url倒数第三位(所有商品排序)0:按上架时间降序,1:按上架时间升序,2:按价格升序,3:按价格降序,4:按好评,5:按销量;
sbg.shelvesTimeArray[] = "";//Url倒数第二位(商品仅显示有货)0:显示全部,1:仅显示有货;
sbg.shelvesTimeArray[] = "";//Url倒数第一位(商品分页)【所传过来的分页】
sbg.Goodses = sbg.Goodses
.Where(s => s.GoodsSKUs.Count > )
.OrderByDescending(f => f.GoodsAddTime)
.Select(f => f)
.ToList();//排序(只显示有goodsSku的商品)
int page = sbg.Goodses.Count;
if (page % == )//取模分页
{
page = page / ;
}
else
{
page = (page / ) + ;
}
sbg.page = page;//商品有多少页
sbg.Goodses = sbg.Goodses.Skip().Take().ToList();
#endregion return View(sbg); #endregion
}
else//都不为空
{
#region -------------二次请求---商品 GoodsType gds = db.GoodsTypes.Find(id);//转换 string[] strs = pvlueIDs.Split('-');//截断字符串 string[] str = strs.Take().ToArray();//品牌ID string[] strPro = strs.Skip().Take(strs.Length - ).ToArray();//从第二个到倒数第四个截断的字符串数组(包括倒数第四个) SKUtypebrandgoods sku = new SKUtypebrandgoods();//中间表 sku.shelvesTimeArray = strs.Skip(strs.Length - ).Take().ToArray();//Url后三位截断字符串赋值
sku.BrandID = Int32.Parse(str[]);//品牌ID
sku.GoodsBrandLst = db.Goodss//商品品牌
.Where(f => f.GoodsTypeID == gds.GoodsTypeID)
.Select(f => f.GoodsBrand)
.Distinct()
.ToList();
var pro = from f in db.GoodsPropertys
where f.GoodsType.GoodsTypeID == id
select f;
int ig = pro.ToList().Count;
GoodsProperty[] pros = new GoodsProperty[ig];
for (int i = ; i < ig; i++)
{
pros[i] = new GoodsProperty();
pros[i].GoodsPropertyID = int.Parse(strPro[i]);
}
sku.GproArray = pros; #region -------------商品Linq语句
sku.SmallType = gds;
GoodsType middleType = db.GoodsTypes//商品中类
.Where(f => f.GoodsTypeID == id)
.Select(f => f.GoodsTypes)
.ToArray()[];
sku.BigType = db.GoodsTypes//商品大类
.Where(f => f.GoodsTypeID == middleType.GoodsTypeID)
.Select(f => f.GoodsTypes)
.ToArray()[];
sku.GoodsProertyLst = db.GoodsPropertys//商品属性
.Where(f => f.GoodsType.GoodsTypeID == id)
.Select(f => f)
.ToList();
sku.GoodsPropertyValueLst = db.GoodsPropertyValues.ToList();//所有商品属性值
#endregion
var goodslst = db.Goodss//商品类别全部商品
.Where(f => f.GoodsTypeID == id)
.Select(f => f);
#region -------------商品属性值筛选
if (sku.BrandID > )
{
goodslst = goodslst
.Where(f => f.GoodsBrandID == sku.BrandID)
.Select(f => f);
}
foreach(var v in strPro)
{
if (v == "")
{
continue;//继续
}
else
{
int propertyValueID = int.Parse(v);
var pvgs = db.PropertyValueGoods
.Where(f => f.GoodsPropertyValueID == propertyValueID)
.Select(f => f);
goodslst = from f in goodslst
join s in pvgs
on f.GoodsID equals s.GoodsID
select f;
}
}
sku.Goodses = goodslst.Where(s => s.GoodsSKUs.Count > ).Distinct().ToList();
#endregion #region -------------商品排序筛选 if (sku.shelvesTimeArray[] == "")//Url倒数第三位(所有商品排序)0:按上架时间降序,1:按上架时间升序,2:按价格升序,3:按价格降序,4:按好评,5:按销量;
{
sku.Goodses = goodslst.OrderByDescending(f => f.GoodsAddTime).ToList();
}
else if(sku.shelvesTimeArray[] == "")
{
sku.Goodses = goodslst.OrderBy(f => f.GoodsAddTime).ToList();
}
else if (sku.shelvesTimeArray[] == "")
{
sku.Goodses = sku.Goodses
.OrderBy(f => f.GoodsSKUs.OrderBy
(fs => fs.GoodsNormalPrice)
.Select(fs => fs).ToArray()[]
.GoodsNormalPrice)
.Select(f => f)
.ToList();
}
else if (sku.shelvesTimeArray[] == "")
{
sku.Goodses = sku.Goodses
.OrderByDescending(f => f.GoodsSKUs.OrderBy
(fs => fs.GoodsNormalPrice)
.Select(fs => fs).ToArray()[]
.GoodsNormalPrice)
.Select(f => f)
.ToList();
}
else if (sku.shelvesTimeArray[] == "")//好评度
{ }
else if (sku.shelvesTimeArray[] == "")
{ }
else
{
return HttpNotFound();
}
#endregion #region -------------是否仅显示有货的商品
if (sku.shelvesTimeArray[] == "")//Url倒数第二位(商品仅显示有货)0:显示全部,1:仅显示有货;
{
}
else if (sku.shelvesTimeArray[] == "")
{
//商品库存数量 != Null
sku.Goodses = sku.Goodses
.Where(f => f.GoodsSKUs.Where(fs => fs.GoodsQty > ).Select(fs => fs).ToList().Count > )
.Select(f => f)
.ToList();
}
#endregion #region -------------商品分页
int page;
if (sku.Goodses.Count % == )
{
page = sku.Goodses.Count / ;
}
else
{
page = (sku.Goodses.Count / ) + ;
}
sku.page = page;
int currentPage = ;
string pageStr = sku.shelvesTimeArray[];
bool parseOk = int.TryParse(pageStr,out currentPage);
if(currentPage - <= )
{
sku.Goodses = sku.Goodses.Take().ToList();//表示第一页
}
else
{
sku.Goodses = sku.Goodses.Skip((currentPage - )*).Take().ToList();//商品分页当前页
} #endregion return View(sku); #endregion
}
}
#endregion
}
Mvc里查询商品页面的更多相关文章
- 在Asp.net MVC中访问静态页面
有时候由于一些特殊的需要,我们需要在MVC中访问HTML页面,假如您将这个页面放在Views中的话,去访问将会收到一个404,但是放在Views外面的目录则不受此限制. 那么我们就来解决View里面的 ...
- asp.net mvc异步查询
对于asp.net mvc异步查询 如何做MVC异步查询,做列表页面. 查询是项目中必不可少的工作,而且不同的项目不同的团队,都有自己的简单方法.Asp.net mvc 有自己独特的优势,下面是结合m ...
- Struts2学习笔记NO.1------结合Hibernate完成查询商品类别简单案例(工具IDEA)
Struts2学习笔记一结合Hibernate完成查询商品类别简单案例(工具IDEA) 1.jar包准备 Hibernate+Struts2 jar包 struts的jar比较多,可以从Struts官 ...
- 对于asp.net mvc异步查询
如何做MVC异步查询,做列表页面. 查询是项目中必不可少的工作,而且不同的项目不同的团队,都有自己的简单方法.Asp.net mvc 有自己独特的优势,下面是结合mvc实现一个产品列表的Demo. 问 ...
- 使用cookies查询商品详情
易买网项目完工,把一些新知识记录下来,以便以后查阅,也方便他人借阅.介绍使用cookies查询商品详情. 第一步:建立商品实体类. 第二步:连接Oracle数据库. 第三步:使用三层架构. 效果图如下 ...
- MVC设计模式-查询与删除
MVC是Model-View-Controller的简称,即模型-视图-控制器.MVC是一种设计模式,它把应用程序分成三个核心模块: 模型:模型是应用程序的主体部分,模型表示业务数据和业务逻辑. 一个 ...
- 零基础学习java------34---------登录案例,域,jsp(不太懂),查询商品列表案例(jstl标签)
一. 简单登录案例 流程图: 项目结构图 前端代码: <!DOCTYPE html> <html> <head> <meta charset="UT ...
- ASP.NET MVC 5 - 查询Details和Delete方法
在这部分教程中,接下来我们将讨论自动生成的Details和Delete方法. 查询Details和Delete方法 打开Movie控制器并查看Details方法. public ActionResul ...
- 记住 MVC里用formcollection接收form表单传来的值,表单属性必须有name为健!
记住 MVC里用formcollection接收form表单传来的值,input属性必须有name为健! 调了一晚上!! 写个日志记下!!
随机推荐
- VMware双网卡实现虚拟机连开发板和Internet
前面已经介绍过关于VMware产生的虚拟交换机和虚拟网卡,当宿主机拥有两个网卡时,可以让虚拟系统同时实现上网和连接开发板的功能. 首先,在设置中虚拟出两块虚拟机网卡,一块连接VMnet0交换机一块连接 ...
- js 推断 当页面无法回退时(history.go(-1)),关闭网页
在做一个Web项目时遇到一个需求,当页面没有前驱历史记录时(就是当前为新弹出的页面,没法做goback操作即history.go(-1)),点击返回button时直接关闭页面,否则就退回到前一页. 遇 ...
- PHP 生成UUID的方法
. . . ...
- Oracle触发器Trigger2行级
create table trigger_t2( id int, name ), age int ); /* --创建一个before update的触发器-控制每一行,行级 --只有行级的才会有:n ...
- UIButton 头文件常见属性和方法
UIButton头文件常见属性 1.属性 contentEdgeInsets: default is UIEdgeInsetsZero.设置内容四边距,默认边距为0 @property(nonatom ...
- jQuery :lt()选择器
定义和用法 :lt() 选择器选取 index 值小于指定数字的元素.(不包含指定值) index 值从 0 开始.(从0开始计数) 最常见的用法:与其他选择器一起使用,选取指定组合中特定序号之前的元 ...
- cvReleaseImage()函数说明
IplImage *tmp = NULL; 这一句话定义了一个IplImage类型的指针变量tmp,这个指针变量在内存中的示意图为: tmp = cvLoadImage(file_path); 这句话 ...
- ZRender源码分析5:Shape绘图详解
回顾 上一篇说到:ZRender源码分析4:Painter(View层)-中,这次,来补充一下具体的shape 关于热区的边框 以圆形为例: document.addEventListener('DO ...
- MySQL表结构同步工具 mysql-schema-sync
mysql-schema-sync 是一款使用go开发的.跨平台的.绿色无依赖的 MySQL 表结构自动同步工具.用于将线上(其他环境)数据库结构变化同步到测试(本地)环境! 可以解决多人开发,每人都 ...
- python2.X和python3.X在同一平台下的切换技巧
python2.X和python3.X在同一平台下的切换技巧 最近在自己的电脑上同时安装了python2.7.11和python3.5.1 在网上搜了一些答案,主要还是参照<learning p ...