华域联盟 .Net ASP.NET笔记之Calender的使用说明

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

1、介绍

(1、在Calender中,所有可选择的符号会显示下划线,这是因为它们在浏览器都会呈现为链接。

     如果让用户可以选择某天、月、周,必须设置SelectionMode属性(Day、 DayWeek、DayWeekMonth)

 

(2   控件事件  当用户选择了某一天或者月,可以用OnSelectionChanged来触发

     通过  Calendar1.SelectedDate.ToShortDateString();来获取所选择的时间点
     通过  Calendar1.SelectedDate.Count.ToString();来获取所选择的天数

2、实例

现在通过一个实例来加深对日历控件的理解:

当点击TGIF时,会在日历上显示所选月份的所有星期五

当点击Apply时,会在日历上显示开始到结束的日期

 Calender.aspx.cs

复制代码 代码如下:

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();

     }

 }

Calender.aspx

复制代码 代码如下:

<%@ 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">&nbsp;</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>

总结: 

(1  采用一些重构,将一些函数方法分离出去,这一块有一些还没分离完全

(2  日期控件还有VisiblMonthChanged事件来处理日历是否被用户更改了月份,   e.NewDate.Year 和e.PreviousDate.Year诸如此类的比较

(3 DayRender事件,可以通过cell和Day来呈现日期的特殊性,例如周末和节假日的颜色,  

             e.Day.IsOtherMOnth    e.Day.IsWeekend  等

您可能感兴趣的文章:

  • Android自定义日历Calender代码实现
  • 一起学写js Calender日历控件
  • php Calender(日历)代码分享
  • php calender(日历)二个版本代码示例(解决2038问题)
  • jQuery web 组件 后台日历价格、库存设置的代码
  • javascript实现的淘宝旅行通用日历组件用法实例
  • js Calender控件使用详解
  • Jquery Easyui搜索框组件SearchBox使用详解(19)
  • jQuery EasyUI框架中的Datagrid数据表格组件结构详解
  • Jquery Easyui日历组件Calender使用详解(23)

本文由 华域联盟 原创撰写:华域联盟 » ASP.NET笔记之Calender的使用说明

转载请保留出处和原文链接:https://www.cnhackhy.com/49474.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部