這篇文章主要介紹Calendar實(shí)現(xiàn)blog日歷的方法,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
“專業(yè)、務(wù)實(shí)、高效、創(chuàng)新、把客戶的事當(dāng)成自己的事”是我們每一個(gè)人一直以來堅(jiān)持追求的企業(yè)文化。 創(chuàng)新互聯(lián)公司是您可以信賴的網(wǎng)站建設(shè)服務(wù)商、專業(yè)的互聯(lián)網(wǎng)服務(wù)提供商! 專注于網(wǎng)站制作、成都做網(wǎng)站、軟件開發(fā)、設(shè)計(jì)服務(wù)業(yè)務(wù)。我們始終堅(jiān)持以客戶需求為導(dǎo)向,結(jié)合用戶體驗(yàn)與視覺傳達(dá),提供有針對(duì)性的項(xiàng)目解決方案,提供專業(yè)性的建議,創(chuàng)新互聯(lián)建站將不斷地超越自我,追逐市場(chǎng),引領(lǐng)市場(chǎng)!
怎樣用.net的Calendar控件來實(shí)現(xiàn)blog中站點(diǎn)日歷的效果呢,我們知道站點(diǎn)日歷最重要的功能就是,顯現(xiàn)在哪天blog主人寫了日志,點(diǎn)擊日期,你將進(jìn)入所選日期的日志列表,
首先,我們知道.net中的服務(wù)器控件是會(huì)進(jìn)行Postback的,Calendar控件中的第一天在點(diǎn)擊時(shí),就會(huì)進(jìn)行一次postback我們要做的就是改變它默認(rèn)的鏈接,使它不觸發(fā)postback事件,其次,就是要知道哪一天有沒有日志。至于有沒有日志,就要去數(shù)據(jù)庫查詢了。
在Calendar中有一個(gè)DayRender事件,該事件在呈現(xiàn)每一天時(shí)觸發(fā),我們可以從這里入手,首先定義一個(gè)數(shù)組變量:
private int[] arrCurrentDays, arrPreDays, arrNextDays; //三個(gè)變量分別是當(dāng)前月,前一月,和下一個(gè)月 private int intCurrentMonth, intPreMonth, intNextMonth; //三個(gè)整型數(shù)組存放相對(duì)月份寫有blog的日期
然后在Calendar的DayRender事件中寫下如下代碼:
CalendarDay d = ((DayRenderEventArgs)e).Day; TableCell c = ((DayRenderEventArgs)e).Cell; // 初始化當(dāng)前月有Blog的日期數(shù)組 if (intPreMonth == 0) { intPreMonth = d.Date.Month; // 注意:日歷控件初始化時(shí)我們得到的第一個(gè)月并不是當(dāng)前月,而是前一個(gè)月的月份 intCurrentMonth = intPreMonth + 1; if (intCurrentMonth > 12) intCurrentMonth = 1; intNextMonth = intCurrentMonth + 1; if (intNextMonth > 12) intNextMonth = 1; arrPreDays = getArrayDay(d.Date.Year, intPreMonth); //得到前一個(gè)月有blog的日期數(shù)組 arrCurrentDays = getArrayDay(d.Date.Year, intCurrentMonth);//得到當(dāng)月有blog的日期數(shù)組 arrNextDays = getArrayDay(d.Date.Year, intNextMonth);//得到下個(gè)月有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("" + d.Date.Day + "")); } 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("" + d.Date.Day + "")); } 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("" + d.Date.Day + "")); } j++; }
在這里我們注意的是getArrayDay()
方法是從數(shù)據(jù)庫里查詢當(dāng)月是否有日志的方法,它返回的是一個(gè)數(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方法,它返回的是一個(gè)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; }
以上是Calendar實(shí)現(xiàn)blog日歷的方法的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!