日曆控制項是.net自帶的控制項之一,功能強大,在許多專案開發中都有用到,對blog系統來說更是不可或缺。縱是好玉也仍需雕琢,為了讓它更美觀實用,我們還需要對它進行二次開發。
新建一個使用者控件,把calender控件拉進來。第一步是外觀設置,這個根據你的需要,只需對它的相關屬性做一些調整。下圖是我調整後的介面
屬性設定如下:
<asp:calendar id="Calendar1" CellPadding="2" Width="160px" TitleStyle-BackColor="#000000" BorderColor="#aaaaaa" DayHeaderStyle-BackColor="#5e715e" OtherMonthDayStyle-ForeColor="#cccccc" DayNameFormat="Full" runat="server" TitleStyle-ForeColor="#ffffff" NextPrevStyle-ForeColor="#ffffff" CellSpacing="1" WeekendDayStyle-BackColor="#eeeeee" DayHeaderStyle-ForeColor="#ffffff" SelectionMode="None" TodayDayStyle-BorderColor="#5e715e" TodayDayStyle-BorderWidth="1" TodayDayStyle-Font-Bold="true" TodayDayStyle-ForeColor="#5e715e" >
第二步是對內部功能的調整,這個工作主要集中在以下兩個事件的處理上。
PreRender:當伺服器控制項將要呈現給其包含的Page物件時發生。
DayRender:當為Calendar控制項在控制項層次結構中建立每一天時發生。
先定義三個整數變數和整數陣列
private int[] arrCurrentDays,arrPreDays,arrNextDays; //三个变量分别是当前月,前一月,和下一个月 private int intCurrentMonth,intPreMonth,intNextMonth; //三个整型数组存放相对月份写有blog的日期 protected System.Web.UI.WebControls.Calendar Calendar1; //这个就是我们的日历控件了
2. 下面我將分別給出這兩個事件的來源碼,並且在下面解釋它實現的功能,如果你看不明白,可以先看下面的說明
PreRender
private void Calendar1_PreRender(object sender, System.EventArgs e) { Thread threadCurrent = Thread.CurrentThread; CultureInfo ciNew = (CultureInfo)threadCurrent.CurrentCulture.Clone(); ciNew.DateTimeFormat.DayNames = new string[]{"日","一","二","三","四","五","六"}; ciNew.DateTimeFormat.FirstDayOfWeek = DayOfWeek.Sunday; threadCurrent.CurrentCulture = ciNew; }
以上程式碼改變了星期名稱的顯示。你只要改變字元陣列的值就能改名稱顯示。
DayRender
private void Calendar1_DayRender(object sender, System.Web.UI.WebControls.DayRenderEventArgs e) { //该控件在创建每一天时发生。 CalendarDay d = ((DayRenderEventArgs)e).Day; TableCell c = ((DayRenderEventArgs)e).Cell; }
以上是詳解關於Blog實作一個日曆的實例教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!