ASP.NET My97DatePicker日期控件实现OA日期记事功能


My97DatePicker日期控件是一个非常好用的日期控件,功能非常优秀的日期控件.
对实现页面刷新完善的很好,用日期控件时可以有比较好的享受,这次的OA日期记事功能也得益于此控件,具体效果图如下:

部分代码:
Default页布局一个Calendar日期控件

 <div>
    <asp:Calendar ID="Calendar1" runat="server" Width="100%" 
      ShowGridLines="True" ondayrender="Calendar1_DayRender" >
    </asp:Calendar>
  </div>

Default页cs代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Text;

public partial class _Default : System.Web.UI.Page 
{
  private DataTable table ;

  protected void Page_Load(object sender, EventArgs e)
  {
    
  }
  protected void Calendar1_DayRender(object sender, DayRenderEventArgs e)
  {
    //获取现在绑定的日期
    CalendarDay day = e.Day;
    //获取当前日期的单元格
    TableCell cell = e.Cell;

    int currentMonth = DateTime.Now.Month ;
    cell.Controls.Clear();
    table = PlanOperator.SelectPlanByMonth(day.Date);
    if (day.Date.Month >= currentMonth)
    {
      StringBuilder builder = new StringBuilder();
      builder.AppendFormat("<font color='Blue'><h5>{0}</h5></font><img src='images/add.png' alt='添加日程' onclick='window.open(\"EditPlan.aspx?Action=New&StartDate={0}\",\"\",\"menu=no,tool=no,status=no,width=400,height=500\");' /> <br/>", day.Date.ToShortDateString());
      DataRow[] planRows = table.Select(string.Format("StartDate<='{0}' AND EndDate>='{1}' ", day.Date, day.Date.AddDays(1)));

      cell.Style["background-color"] = planRows.Length <= 0 ? "#E9E9E9" : "#FFFFFF";

      int index = 1;
      foreach (DataRow row in planRows)
      {
        string title = row["Title"].ToString().Length > 10 ? row["Title"].ToString().Substring(0, 10) + "..." : row["Title"].ToString();
        builder.AppendFormat("<a onclick='window.open(\"EditPlan.aspx?Action=Edit&PlanID={1}\",\"\",\"menu=no,tool=no,status=no,width=400,height=500\");'>{0}.{2}</a><br/>", index, row["PlanID"], title);
        index++;
        continue;
      }

      cell.Controls.Add(new LiteralControl(builder.ToString()));
    }
    else
    {
      cell.Style["background-color"] = "#E9E9E9"; 
    }
  }


  
}

控件编辑前台代码:

<head runat="server">
  <title></title>
  <script type="text/javascript" language="javascript" src="My97DatePicker/WdatePicker.js">
  </script>
  <script type="text/javascript" language="javascript">
    function valiStartDate(source, clientside_arguments) {
      if (clientside_arguments.Value > new Date()) {
        clientside_arguments.IsValid = true;
      }
      else {
        clientside_arguments.IsValid = false;
      }
    }
  </script>
</head>
<body>
  <form id="form1" runat="server">
  <h3>日程信息</h3>
  <div >
    日程主题:<asp:TextBox runat="server" ID="txtTitle" Width="270px" 
      BorderColor="#0066FF" BorderStyle="Solid" BorderWidth="1px" ></asp:TextBox> <br />
    日程内容:<asp:TextBox runat="server" ID="txtContent" TextMode="MultiLine" Height="96px"></asp:TextBox> <br />
    起始日期:<asp:TextBox runat="server" ID="txtStartDate" CssClass="Wdate" onfocus="WdatePicker({minDate:'%y-%M-01',dateFmt:'yyyy-MM-dd HH:mm',maxDate:'%y-%M-%ld'})" /></asp:TextBox>
    <br />
    结束日期:<asp:TextBox runat="server" ID="txtEndDate" CssClass="Wdate" onfocus="WdatePicker({minDate:'%y-%M-01',dateFmt:'yyyy-MM-dd HH:mm',maxDate:'%y-%M-%ld'})" /></asp:TextBox>
    <asp:Panel runat="server" ID="pnlNew">
      <asp:Button runat="server" ID="btnInsertPlan" Text="添加" 
        onclick="btnInsertPlan_Click" />
                 
                 
      <input type="reset" id="btnReset" value="重置" />
    </asp:Panel>
    <asp:Panel runat="server" ID="pnlEdit">
       <asp:Button runat="server" ID="btnUpdate" Text="更新" 
         onclick="btnUpdate_Click1" />
                 
                 
      <asp:Button runat="server" ID="btnDelete" Text="删除" onclick="btnDelete_Click" 
         />
      <asp:HiddenField runat="server" ID="hidPlanID" />
    </asp:Panel>
    <asp:ValidationSummary ID="ValidationSummary1" runat="server" 
      HeaderText="提交对日程的修改中出现了以下问题:" /><br />
  </div>
  </form>
</body>

控件编辑后台cs:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;

public partial class EditPlan : System.Web.UI.Page
{
  public DateTime StartDate
  {
    get { return (DateTime)this.ViewState["StartDate"]; }
    set { this.ViewState["StartDate"] = value; }
  }

  public DateTime EndDate
  {
    get { return (DateTime)this.ViewState["EndDate"]; }
    set { this.ViewState["EndDate"] = value; }
  }

  

  protected void Page_Load(object sender, EventArgs e)
  {
    if (this.Request.QueryString.Count != 2)
    {
      this.Response.End();
      return;
    }

    if (!this.IsPostBack)
    {
      string action = this.Request.QueryString["Action"];


      switch (action)
      {
        case "New":
          this.StartDate = Convert.ToDateTime(this.Request.QueryString["StartDate"]);
          this.EndDate = new DateTime(DateTime.Now.Year, DateTime.Now.Month, (DateTime.Now.AddMonths(1) - DateTime.Now).Days);
          this.pnlNew.Visible = true;
          this.pnlEdit.Visible = false;
          break;
        case "Edit":
          int planID = Convert.ToInt32(this.Request.QueryString["PlanID"]);
          DataTable table = PlanOperator.SelectPlanById(planID);
          this.txtTitle.Text = table.Rows[0]["Title"].ToString();
          this.txtContent.Text = table.Rows[0]["PlanContent"].ToString();
          this.txtStartDate.Text = table.Rows[0]["StartDate"].ToString();
          this.txtEndDate.Text = table.Rows[0]["EndDate"].ToString();
          this.hidPlanID.Value = table.Rows[0]["PlanID"].ToString();
          this.pnlNew.Visible = false;
          this.pnlEdit.Visible = true;
          break;
        default:
          break;
      }
    }
  }

  protected void btnInsertPlan_Click(object sender, EventArgs e)
  {
    int i=PlanOperator.InsertPlan(this.txtTitle.Text, this.txtContent.Text,this.txtStartDate.Text, this.txtEndDate.Text);
    if (i == 1)
    {
      this.Response.Write("<script type='text/javascript' language='javascript'>alert('添加日程成功!'); window.opener.location=window.opener.location+'?'+Math.random();window.opener='';window.close();</script>");
      return;
    }
    this.Response.Write("<script type='text/javascript' language='javascript'>alert('添加日程失败!'); window.opener.location=window.opener.location+'?'+Math.random();window.opener='';window.close();</script>");
    return;
  }

  protected void btnUpdate_Click1(object sender, EventArgs e)
  {
    int i = PlanOperator.UpdatePlan(Convert.ToInt32(this.hidPlanID.Value),this.txtTitle.Text, this.txtContent.Text, this.txtStartDate.Text, this.txtEndDate.Text);
    if (i == 1)
    {
      this.Response.Write("<script type='text/javascript' language='javascript'>alert('更新日程成功!'); window.opener.location=window.opener.location+'?'+Math.random();window.opener='';window.close();</script>");
      return;
    }
    this.Response.Write("<script type='text/javascript' language='javascript'>alert('更新日程失败!'); window.opener.location=window.opener.location+'?'+Math.random();window.opener='';window.close();</script>");
    return;
  }

  protected void btnDelete_Click(object sender, EventArgs e)
  {
    int i = PlanOperator.DeletePlan(Convert.ToInt32(this.hidPlanID.Value));
    if (i == 1)
    {
      this.Response.Write("<script type='text/javascript' language='javascript'>alert('删除日程成功!'); window.opener.location=window.opener.location+'?'+Math.random();window.opener='';window.close();</script>");
      return;
    }
    this.Response.Write("<script type='text/javascript' language='javascript'>alert('删除日程失败!'); window.opener.location=window.opener.location+'?'+Math.random();window.opener='';window.close();</script>");
    return;
  }
}

以上就是关于My97DatePicker日期控件实现OA日期记事功能的全部内容,希望大家会喜欢。



相关阅读:
C#处理Paint事件的方法
PHP中static关键字以及与self关键字的区别
ajax回调函数中使用$(this)取不到对象的解决方法
Java中的static关键字全面解析
JavaScript获取表单enctype属性的方法
快速解决Win7系统提示此windows副本不是正版的方法
水晶报表asp.net的webform下基本用法实例
JavaScript 实现完美兼容多浏览器的复制功能代码
详解Android中Handler的使用方法
CSS background全部汇总
CSS样式定义的优先级顺序介绍
js实现文本框选中的方法
详解对Linux内核进行升级的步骤
asp.net不用设置iis实现url重写 类似伪静态路由
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 小学五年级作文500字:风 #183;影 母亲节的感受作文 励志电影推荐《一公升的眼泪》 丫头,我那永恒的爱恋 小学四年级作文400字:关羽 对加快餐饮业工作发展的思考 蜗牛背着重重的壳 作一个温柔的微笑来回应 慈善捐助超市开业仪式讲话稿 东北老工业基地国有经济的现状 卖报纸——难呀作文800字 经典语录:感情再深,不懂珍惜也会断! dnf魔法师2作文2800字 感谢老师的作文300字 2012学年上学期英语教学工作总结 我爱上了这习惯 当你幸福的离去 《威尼斯商人》读后感400字 忘不了那一夜作文800字 小学五年级作文450字:猫狗冤家 汕头市室内装饰设计合同 教师节历年大事记 教育故事案例 防溺水主题班会教案 2016工厂安全心得体会 校园的落叶作文 五年级《放牛班的春天》观后感 我的钢笔 2015最浪漫的爱情句子 家乡的习俗作文300字 青城雪落雨飘零 《太阳雨,月亮雪》第六章(陕西大荔李喜来) 女友过生日祝福语 精彩的海狮表演作文 我最喜爱的三国人物 人事劳动局政府重点工作分解落实的情况总结 两学一做学习体会:重在日常修为 雨别 神王——圣殿 学生贫困证明_证明书 历史上的两次股市大崩盘 妈妈染发了 餐桌上的腐败,不能像“牛皮癣”反反复复 邓小平理论与国际社会主义运动 猪肉涨价的联想 被遗忘到角落 初中初二作文800字:记一次查资料 秋天最后的眷恋 坚强的人生300字 心灵成长励志书籍推荐

Copyright © 2016 phpStudy |