How to get the current week starting date and add it to a combo box?

前端 未结 4 1584
不知归路
不知归路 2021-02-14 10:17

I\'m attempting to recreate a time sheet built on asp and I can\'t figure out how to get the current weeks starting date \"6-13-2010\" and have it populate a combo box can you h

相关标签:
4条回答
  • 2021-02-14 10:26
    DateTime startOfWeek = DateTime.Today.AddDays(-1 * (int)(DateTime.Today.DayOfWeek));
    

    Regarding adding items to a DropDownList in ASP.NET, assuming you're using the webforms model, you would do something like

    yourDropDown.Items.Add(new ListItem(yourText, yourValue));
    
    0 讨论(0)
  • 2021-02-14 10:40
    DateTime.Now.Date.AddDays(-1 * (Int32)DateTime.Now.DayOfWeek)
    
    0 讨论(0)
  • 2021-02-14 10:48
    DateTime startOfWeek = Today.AddDays((int)Today.DayOfWeek * -1)
    

    Likely an off by one error, since it is untested.

    0 讨论(0)
  • 2021-02-14 10:49

    Here's an example that uses an iterator.

        /// <summary>
        /// Gets the dates that mark the beginning of each week from the specified start date until today.
        /// </summary>
        /// <param name="weekStart">The day of the week that marks the beginning of a week</param>
        /// <param name="startDate">A date that determines the earliest week in the result.</param>
        /// <returns></returns>
        public IEnumerable<DateTime> GetWeeks(DayOfWeek weekStart, DateTime startDate)
        {
            DateTime current = DateTime.Today.AddDays(weekStart - DateTime.Today.DayOfWeek);
            while(current >= startDate)
            {
                yield return current;
    
                // move to the previous week
                current = current.AddDays(-7);
            }
        }
    
        public void PopulateUI()
        {
            // in this example, Monday is considered the start of the week,
            // and the drop down list will be populated with the date of each monday starting with this week going back to 1 year ago.
            ddlWeeks.DataSource = GetWeeks(DayOfWeek.Monday, DateTime.Today.AddYears(-1));
        }
    

    You mentioned that you're pretty new to C#, so sorry if it seems confusing. Below is an alternative GetWeeks function that is not defined as an iterator.

        public List<DateTime> GetWeeks(DayOfWeek weekStart, DateTime startDate)
        {
            List<DateTime> result = new List<DateTime>();
    
            DateTime current = DateTime.Today.AddDays(weekStart - DateTime.Today.DayOfWeek);
            while (current >= startDate)
            {
                result.Add(current);
    
                // move to the previous week
                current = current.AddDays(-7);
            }
    
            return result;
        }
    
    0 讨论(0)
提交回复
热议问题