asp.net基于Calendar實現(xiàn)blog日歷功能示例
本文實例講述了asp.net基于Calendar實現(xiàn)blog日歷功能。分享給大家供大家參考,具體如下:
怎樣用.net的Calendar控件來實現(xiàn)blog中站點日歷的效果呢,我們知道站點日歷最重要的功能就是,顯現(xiàn)在哪天blog主人寫了日志,點擊日期,你將進入所選日期的日志列表,
首先,我們知道.net中的服務(wù)器控件是會進行Postback的,Calendar控件中的第一天在點擊時,就會進行一次postback我們要做的就是改變它默認的鏈接,使它不觸發(fā)postback事件,其次,就是要知道哪一天有沒有日志。至于有沒有日志,就要去數(shù)據(jù)庫查詢了。
在Calendar中有一個DayRender事件,該事件在呈現(xiàn)每一天時觸發(fā),我們可以從這里入手,首先定義一個數(shù)組變量:
private int[] arrCurrentDays, arrPreDays, arrNextDays; //三個變量分別是當(dāng)前月,前一月,和下一個月 private int intCurrentMonth, intPreMonth, intNextMonth; //三個整型數(shù)組存放相對月份寫有blog的日期
然后在Calendar的DayRender事件中寫下如下代碼:
CalendarDay d = ((DayRenderEventArgs)e).Day;
TableCell c = ((DayRenderEventArgs)e).Cell;
// 初始化當(dāng)前月有Blog的日期數(shù)組
if (intPreMonth == 0)
{
intPreMonth = d.Date.Month; // 注意:日歷控件初始化時我們得到的第一個月并不是當(dāng)前月,而是前一個月的月份
intCurrentMonth = intPreMonth + 1;
if (intCurrentMonth > 12)
intCurrentMonth = 1;
intNextMonth = intCurrentMonth + 1;
if (intNextMonth > 12)
intNextMonth = 1;
arrPreDays = getArrayDay(d.Date.Year, intPreMonth); //得到前一個月有blog的日期數(shù)組
arrCurrentDays = getArrayDay(d.Date.Year, intCurrentMonth);//得到當(dāng)月有blog的日期數(shù)組
arrNextDays = getArrayDay(d.Date.Year, intNextMonth);//得到下個月有blog的日期數(shù)組
}
int j = 0;
if (d.Date.Month.Equals(intPreMonth))
{
while (!arrPreDays[j].Equals(0))
{
if (d.Date.Day.Equals(arrPreDays[j]))
{
c.Controls.Clear();
c.Controls.Add(new LiteralControl("<a href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" mce_href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" " + d.Date.Year + "&month=" +
d.Date.Month + "&day=" + d.Date.Day + ">" + d.Date.Day + "</a>"));
}
j++;
}
}
else if (d.Date.Month.Equals(intCurrentMonth))
{
while (!arrCurrentDays[j].Equals(0))
{
if (d.Date.Day.Equals(arrCurrentDays[j]))
{
c.Controls.Clear();
c.Controls.Add(new LiteralControl("<a href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" mce_href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" " + d.Date.Year + "&month=" +
d.Date.Month + "&day=" + d.Date.Day + " title=查看"+d.Date.Day+"日日志>" + d.Date.Day + "</a>"));
}
j++;
}
}
else if (d.Date.Month.Equals(intNextMonth))
{
while (!arrNextDays[j].Equals(0))
{
if (d.Date.Day.Equals(arrNextDays[j]))
{
c.Controls.Clear();
c.Controls.Add(new LiteralControl("<a href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" mce_href="day.aspx?year=" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" " + d.Date.Year + "&month=" +
d.Date.Month + "&day=" + d.Date.Day + ">" + d.Date.Day + "</a>"));
}
j++;
}
在這里我們注意的是getArrayDay()方法是從數(shù)據(jù)庫里查詢當(dāng)月是否有日志的方法,它返回的是一個數(shù)組,我寫的內(nèi)容如下:
public int[] getArrayDay(int intYear, int intMonth)
{
int[] intArray = new int[31];
//從數(shù)據(jù)庫里選取符合要求的記錄,將日期存入數(shù)組
string strSql = "select data from test where year(data)=" + intYear +
" and month(data)=" + intMonth;
//調(diào)用DbHelperOleDb自定義類中的ExecuteReader方法,它返回的是一個OleDbDataReader型
OleDbDataReader dr = dbAccess.DbHelperOleDb.ExecuteReader(strSql);
int i = 0;
while (dr.Read())
{
if (i == 0)
{
intArray[i] = Convert.ToDateTime(dr["data"].ToString()).Day;
string a=Convert.ToString(intArray[i]);
i++;
}
else if (Convert.ToDateTime(dr["data"].ToString()).Day != intArray[i - 1])
{
intArray[i] = Convert.ToDateTime(dr["data"].ToString()).Day;
i++;
}
}
return intArray;
}
ok ,這樣就行了,我們運行一下就可以看到效果了..
PS:這里再為大家分享幾款本站的在線日期工具供大家參考:
在線萬年歷日歷:
http://tools.jb51.net/bianmin/wannianli
網(wǎng)頁萬年歷日歷:
http://tools.jb51.net/bianmin/webwannianli
在線萬年歷黃歷flash版:
http://tools.jb51.net/bianmin/flashwnl
更多關(guān)于asp.net相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《asp.net操作json技巧總結(jié)》、《asp.net字符串操作技巧匯總》、《asp.net操作XML技巧總結(jié)》、《asp.net文件操作技巧匯總》、《asp.net ajax技巧總結(jié)專題》及《asp.net緩存操作技巧總結(jié)》。
希望本文所述對大家asp.net程序設(shè)計有所幫助。
- ASP.NET Calendar日歷(日期)控件使用方法
- asp.net中日歷函數(shù)Calendar的使用方法
- ASP.NET中為TextBox中添加calendar.js示例代碼
- ASP.NET中實現(xiàn)彈出日歷示例
- ASP.NET中日歷控件和JS版日歷控件的使用方法(第5節(jié))
- 在ASP.NET中實現(xiàn)彈出日歷的具體方法
- ASP.NET技巧:為Blog打造個性日歷
- ASP.NET如何獲取兩個日期之間的天數(shù)
- asp.net 時間類 一周的周一和周末的日期
- asp.net 日期函數(shù) 某月的第一天和最后一天的日期
- Asp.net 時間操作基類(支持短日期,長日期,時間差)
- asp.net(C#)實現(xiàn)功能強大的時間日期處理類完整實例
相關(guān)文章
.NET Framework常用ORM框架iBatis.Net操作數(shù)據(jù)庫的方法
iBatis.Net 是一個輕量級的 ORM 框架,它允許開發(fā)者通過直接編寫 SQL 查詢來操作數(shù)據(jù)庫,并將查詢結(jié)果映射到對象模型中,本文將通過實際的代碼示例,詳細介紹如何在 .NET 環(huán)境中使用 iBatis.Net 進行數(shù)據(jù)庫操作,感興趣的朋友一起看看吧2024-08-08
基于asp.net下使用jquery實現(xiàn)ajax的解決方法
本文以最簡單的方法為新手示范如何使用jquery實現(xiàn)ajax技術(shù)(所以本文是專為新手所寫,老鳥勿噴,大神此處省略一萬字)。至于什么是jquery什么是ajax,自己谷歌去2013-05-05
使用Entity Framework(4.3.1版本)遇到的問題整理
在這里記錄一下之前使用Entity Framework(4.3.1版本)遇到的問題:更新沒有設(shè)置主鍵的表、更改Code-First的默認連接、檢測字符串截斷錯誤,需要的朋友可以參考下2012-12-12
asp.net 操作XML 按指定格式寫入XML數(shù)據(jù) WriteXml
從SQL下載數(shù)據(jù)到本地為XML文件2009-07-07
使用Aspose.Cells實現(xiàn)導(dǎo)入導(dǎo)出
這篇文章主要為大家詳細介紹了如何使用Aspose.Cells實現(xiàn)導(dǎo)入導(dǎo)出,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12
asp.net datalist綁定數(shù)據(jù)后可以上移下移實現(xiàn)示例
這篇文章主要介紹了asp.net datalist綁定數(shù)據(jù)后可以上移下移的示例代碼,需要的朋友可以參考下2014-02-02
asp.net下Repeater使用 AspNetPager分頁控件
AspNetPager針對ASP.NET分頁控件的不足,提出了與眾不同的解決asp.net中分頁問題的方案2010-03-03

