首頁  >  文章  >  後端開發  >  詳解關於Blog實作一個日曆的實例教程

詳解關於Blog實作一個日曆的實例教程

零下一度
零下一度原創
2017-07-03 17:17:301713瀏覽

日曆控制項是.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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn