源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

ASP.NET笔记之Calender的使用说明

  • 时间:2021-02-22 16:44 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:ASP.NET笔记之Calender的使用说明
[b]1、介绍[/b] (1、在Calender中,所有可选择的符号会显示下划线,这是因为它们在浏览器都会呈现为链接。      如果让用户可以选择某天、月、周,必须设置SelectionMode属性(Day、 DayWeek、DayWeekMonth)                             [img]http://files.jb51.net/file_images/article/201304/2013042410545545.jpg[/img]   (2   控件事件  当用户选择了某一天或者月,可以用OnSelectionChanged来触发      通过  Calendar1.SelectedDate.ToShortDateString();来获取所选择的时间点      通过  Calendar1.SelectedDate.Count.ToString();来获取所选择的天数 [b]2、实例[/b] 现在通过一个实例来加深对日历控件的理解: 当点击TGIF时,会在日历上显示所选月份的所有星期五 当点击Apply时,会在日历上显示开始到结束的日期                     [img]http://files.jb51.net/file_images/article/201304/2013042410545546.jpg[/img] [b] Calender.aspx.cs [/b]
[u]复制代码[/u] 代码如下:
using System;  using System.Collections.Generic;  using System.Linq;  using System.Web;  using System.Web.UI;  using System.Web.UI.WebControls;  public partial class myTest_Calender : System.Web.UI.Page  {      protected void Page_Load(object sender, EventArgs e)      {          if (!IsPostBack) {              my_Calendar.VisibleDate = my_Calendar.TodaysDate;              //将选择的日期中的月份映射到下拉框中              Month_List.SelectedIndex = my_Calendar.VisibleDate.Month - 1;          }          //显示到标签中          lblTodaysDate.Text = "Today is  :" + my_Calendar.TodaysDate.ToShortDateString();      }      //选择一个日期的时候触发函数      protected void Calendar_Select(object sender, EventArgs e)      {          lblCountUpdate();          lblSelectedUpdate();          txtClear();      }      //下拉框触发函数      protected void Month_SelectedChange(object sender, EventArgs e)      {          my_Calendar.SelectedDates.Clear();          lblSelectedUpdate();          lblCountUpdate();          //重新设置时间          my_Calendar.VisibleDate = new DateTime(my_Calendar.VisibleDate.Year,              Int32.Parse(Month_List.SelectedItem.Value), 1);          txtClear();      }      //重构函数01-修改日期的次数      private void lblCountUpdate() {          lblCount.Text = "the Count of Selected:" + my_Calendar.SelectedDates.Count.ToString();            }      //重构函数02-清楚数据      private void txtClear() {          txtEnd.Text = "";          txtStart.Text = "";      }      //重构函数03-修改日期      private void lblSelectedUpdate() {          if (my_Calendar.SelectedDate != DateTime.MinValue)              lblSelctedDate.Text = "the  selected day is :" +                  my_Calendar.SelectedDate.ToShortDateString();      }      //按钮1:显示所选月份的所有星期五      protected void btnTgif_Click(object sender, EventArgs e)      {          int currnetMonth = my_Calendar.VisibleDate.Month;          int curretnYear = my_Calendar.VisibleDate.Year;          //先清除原先日历位置          my_Calendar.SelectedDates.Clear();          //如果日期是星期五则将其添加到日历中          for (int i = 1; i <= System.DateTime.DaysInMonth(              curretnYear, currnetMonth); i++) {                  DateTime datetime = new DateTime(curretnYear, currnetMonth, i);                  if (datetime.DayOfWeek == DayOfWeek.Friday)                      my_Calendar.SelectedDates.Add(datetime);              }          lblSelectedUpdate();          lblCountUpdate();      }      //按钮2:      protected void btnRange_Click(object sender, EventArgs e)      {          int currnetMonth = my_Calendar.VisibleDate.Month;          int curretnYear = my_Calendar.VisibleDate.Year;          DateTime StartDate = new DateTime(curretnYear, currnetMonth,Int32.Parse(txtStart.Text));          DateTime EndtartDate = new DateTime(curretnYear, currnetMonth, Int32.Parse(txtEnd.Text));          my_Calendar.SelectedDates.Clear();          my_Calendar.SelectedDates.SelectRange(StartDate,EndtartDate);          lblCountUpdate();          lblSelectedUpdate();      }  }
[b]Calender.aspx [/b]
[u]复制代码[/u] 代码如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Calender.aspx.cs" Inherits="myTest_Calender" %>  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  <html xmlns="http://www.w3.org/1999/xhtml">  <head runat="server">      <title>Calender  Control</title>  </head>  <body>      <form id="form1" runat="server">      <div>          <h1>Calender  Control</h1>          <h2></h2>          <asp:Calendar ID="my_Calendar" runat="server"                      OnSelectionChanged="Calendar_Select">          </asp:Calendar>          <br  />          <asp:Label ID="lblCount" runat="server" Text="Label"></asp:Label>          <br />          <asp:Label ID="lblTodaysDate" runat="server" Text="Label"></asp:Label>          <br />          <asp:Label ID="lblSelctedDate" runat="server" Text="Label"></asp:Label>          <table>             <tr>                 <td>Select a month</td>                 <td>                     <asp:DropDownList ID="Month_List" runat="server"                         AutoPostBack="true"                         OnSelectedIndexChanged="Month_SelectedChange">                         <asp:ListItem text="January" Value="1" />                         <asp:ListItem text="February" Value="2" />                         <asp:ListItem text="March" Value="3" />                         <asp:ListItem text="April" Value="4" />                         <asp:ListItem text="May" Value="5" />                         <asp:ListItem text="June" Value="6" />                         <asp:ListItem text="July" Value="7" />                         <asp:ListItem text="Augut" Value="8" />                         <asp:ListItem text="September" Value="9" />                         <asp:ListItem text="October" Value="10" />                         <asp:ListItem text="November" Value="11" />                         <asp:ListItem text="December" Value="12" />                     </asp:DropDownList>                 </td>                 <td>                     <asp:Button ID="btnTgif" runat="server"                         Text="TGIF"                         OnClick="btnTgif_Click"/>                 </td>             </tr>             <tr>                 <td  colspan="2"> </td>             </tr>             <tr>                 <td  colspan="2"><b>Day Range</b></td>             </tr>             <tr>                 <td >Starting  Day</td>                 <td >Ending  Day</td>             </tr>             <tr>                 <td >                     <asp:TextBox ID="txtStart" runat="server"                         Width="25" MaxLength="2"></asp:TextBox>                 </td>                 <td >                     <asp:TextBox ID="txtEnd" runat="server"                         Width="25" MaxLength="2"></asp:TextBox>                 </td>                 <td >                     <asp:Button ID="btnRange" runat="server" Text="Apply"                       OnClick="btnRange_Click" style="height: 21px"/>                 </td>             </tr>          </table>      </div>      </form>  </body>  </html>
[b]总结:[/b]  (1  采用一些重构,将一些函数方法分离出去,这一块有一些还没分离完全 (2  日期控件还有VisiblMonthChanged事件来处理日历是否被用户更改了月份,   e.NewDate.Year 和e.PreviousDate.Year诸如此类的比较 (3 DayRender事件,可以通过cell和Day来呈现日期的特殊性,例如周末和节假日的颜色,                e.Day.IsOtherMOnth    e.Day.IsWeekend  等
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部