程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> ASP.NET技巧:為Blog打造個性日歷

ASP.NET技巧:為Blog打造個性日歷

編輯:.NET實例教程
日歷控件是.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;
}
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved