|
新建一個用戶控件,把calender控件拉進(jìn)來。第一步是外觀設(shè)置,這個根據(jù)你的需要,只需對它的相關(guān)屬性做一些調(diào)整即可。下圖是我調(diào)整后的界面
![]() |
屬性設(shè)置如下:
<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" > |
第二步是對內(nèi)部功能的調(diào)整,這個工作主要集中在以下兩個事件的處理上。
PreRender:當(dāng)服務(wù)器控件將要呈現(xiàn)給其包含的Page對象時發(fā)生。
DayRender:當(dāng)為Calendar控件在控件層次結(jié)構(gòu)中創(chuàng)建每一天時發(fā)生。
先定義三個整型變量和整型數(shù)組
private int[] arrCurrentDays,arrPreDays,arrNextDays; //三個變量分別是當(dāng)前月,前一月,和下一個月 private int intCurrentMonth,intPreMonth,intNextMonth; //三個整型數(shù)組存放相對月份寫有blog的日期 protected System.Web.UI.WebControls.Calendar Calendar1; //這個就是我們的日歷控件了 |
2. 下面我將分別給出這兩個事件的源碼,并在下面解釋它實現(xiàn)的功能,如果你看不明白,可以先看下面的說明
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; } |
以上代碼改變了星期名稱的顯示。你只需改變字符數(shù)組的值就能改名稱顯示。
DayRender
private void Calendar1_DayRender(object sender, System.Web.UI.WebControls.DayRenderEventArgs e) { //該控件在創(chuàng)建每一天時發(fā)生。 CalendarDay d = ((DayRenderEventArgs)e).Day; TableCell c = ((DayRenderEventArgs)e).Cell; } |
AspNet技術(shù):ASP.NET技巧:為Blog打造個性日歷,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。