欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

asp.net基于Calendar實(shí)現(xiàn)blog日歷功能示例

 更新時間:2017年07月05日 11:06:19   作者:china_skag  
這篇文章主要介紹了asp.net基于Calendar實(shí)現(xiàn)blog日歷功能,涉及asp.net使用Calendar控件操作日期與時間相關(guān)運(yùn)算技巧,需要的朋友可以參考下

本文實(shí)例講述了asp.net基于Calendar實(shí)現(xiàn)blog日歷功能。分享給大家供大家參考,具體如下:

怎樣用.net的Calendar控件來實(shí)現(xiàn)blog中站點(diǎn)日歷的效果呢,我們知道站點(diǎn)日歷最重要的功能就是,顯現(xiàn)在哪天blog主人寫了日志,點(diǎn)擊日期,你將進(jìn)入所選日期的日志列表,

首先,我們知道.net中的服務(wù)器控件是會進(jìn)行Postback的,Calendar控件中的第一天在點(diǎn)擊時,就會進(jìn)行一次postback我們要做的就是改變它默認(rèn)的鏈接,使它不觸發(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 ,這樣就行了,我們運(yùn)行一下就可以看到效果了..

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è)計有所幫助。

相關(guān)文章

最新評論