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为健! 调了一晚上!! 写个日志记下!!
随机推荐
- uva12096 The SetStack Computer By sixleaves
代码 typedef map<Set, vector<Set> Setcache; stack< ci ...
- IVM import vector machine
本文为<Kernel Logistic Regression and the Import Vector Machine>的阅读笔记是技法课的课外阅读 Abstract:基于KLR ker ...
- 深入理解JavaScript的闭包特性 如何给循环中的对象添加事件(转载)
原文参考:http://blog.csdn.net/gaoshanwudi/article/details/7355794 初学者经常碰到的,即获取HTML元素集合,循环给元素添加事件.在事件响应函数 ...
- system函数遇到的问题 - 程序死掉
system函数遇到的问题 解决方案见最下边 http://blog.csdn.net/yangzhenzhen/article/details/51505176 这几天调程序(嵌入式linux),发 ...
- 你知道为什么Xcode6中Swift没有智能提示和自己主动补全功能吗 ?
你知道为什么Xcode6中Swift没有智能提示和自己主动补全功能吗 ? 长沙戴维营教育将为你解开这个巨大的谜团大BUG! http://www.ubuntucollege.cn/course/29/ ...
- 样式布局分享-基于frozen.js的移动OA
最近改造了公司移动OA的样式,改善了显示效果和用户体验,其中用到了腾讯的 frozen.js 框架,在此把布局代码分享给大家,希望大家可以用得上,具体效果如下图. Demo 百度网盘 下载地址 Git ...
- Jquery实现鼠标hover图片遮罩弹出提示层特效
1.引入JS文件和所需要的样式文件 2.简单的写上以下18行代码就可以实现了 $(document).ready(function() { $("div.tip_trigger a.img& ...
- MySql按指定天数进行分组数据统计分析 1
这几天,在做数据统计,在对数据库数据进行统计过程中,有个需求就是要按照指定天数进行分组, 之前一直没有找到好的方法,就先取出数据,在程序中进行分组. 后发现,可以在SQL语句中实现按天数分组. 例: ...
- Android 测试工具集01
Appium是一个支持原生,混合和移动web apps的开源的跨平台测试框架工具. ANDROID依赖 Android SDK API >= 17 (Additional features re ...
- Binder的使用(跨进程——AIDL,非跨进程)
一.Binder类 1.作用:Binder是客户端与服务器端的通信的媒介(连接各种Manager的桥梁),客户端通过Binder对象获取服务器端提供的数据 (为什么要用Binder来提供数据呢,服务器 ...