• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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笔记之页面跳转、调试、form表单、viewstate、cookie的使用说明
    下一篇:ASP.NET笔记之广告控件的使用方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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