包含周的下拉列表
本文关键字:下拉列表 包含周 | 更新日期: 2023-09-27 18:17:21
我在一个内部网站点工作,专门为员工开发每周监测工具。我需要的是用周填充DropDownList
,例如周:
Week : From 12/10/15 to 18/10/15
我可以在另一个页面上过滤,但是年份和月份:
CalendarController c = new CalendarController();
ViewBag.ListYears = c.ListYears(iyear);
ViewBag.ListMonths = c.ListMonths(imonth);
ViewBag.ListDaysOfMonth = _service.ListDaysOfMonth(iyear.ToString(), imonth.ToString());
并使用表单来保存它们。
我如何用一个列表填充我的DDList,比如说,2015年的所有星期?
要返回格式化的星期列表,可以使用以下方法
public List<string> FetchWeeks(int year)
{
List<string> weeks = new List<string>();
DateTime startDate = new DateTime(year, 1, 1);
startDate = startDate.AddDays(1 - (int)startDate.DayOfWeek);
DateTime endDate = startDate.AddDays(6);
while (startDate.Year < 1 + year)
{
weeks.Add(string.Format("Week: From {0:dd/MM/yyyy}to {1:dd/MM/yyyy}", startDate, endDate));
startDate= startDate.AddDays(7);
endDate = endDate.AddDays(7);
}
return weeks;
}
然后在控制器
var weeks = FetchWeeks(2105);
ViewBag.Weeks = new SelectList(weeks);
但是,这将返回格式化的值,这可能在控制器中没有多大用处,因此可以修改,以便创建IEnumerable<SelectListItem>
,其中Value
属性是表示一年中星期索引的数字,Text
属性是格式化的文本。
如何获得当年的星期(这里值得称赞):
var jan1 = new DateTime(DateTime.Today.Year , 1, 1);
//beware different cultures, see other answers
var startOfFirstWeek = jan1.AddDays(1 - (int)(jan1.DayOfWeek));
var weeks=
Enumerable
.Range(0,54)
.Select(i => new {
weekStart = startOfFirstWeek.AddDays(i * 7)
})
.TakeWhile(x => x.weekStart.Year <= jan1.Year)
.Select(x => new {
x.weekStart,
weekFinish=x.weekStart.AddDays(4)
})
.SkipWhile(x => x.weekFinish < jan1.AddDays(1) )
.Select((x,i) => new {
x.weekStart,
x.weekFinish,
weekNum=i+1
});
然后将周添加到下拉列表