• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    ASP.NET My97DatePicker日期控件实现OA日期记事功能
    POST TIME:2021-10-18 02:18

    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=NewStartDate={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=EditPlanID={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" />
          nbsp; nbsp; nbsp; nbsp; nbsp; nbsp;
           nbsp;nbsp; nbsp; nbsp; nbsp; nbsp;
          input type="reset" id="btnReset" value="重置" />
        /asp:Panel>
        asp:Panel runat="server" ID="pnlEdit">
           asp:Button runat="server" ID="btnUpdate" Text="更新" 
             onclick="btnUpdate_Click1" />
          nbsp; nbsp; nbsp; nbsp; nbsp; nbsp;
           nbsp;nbsp; nbsp; nbsp; nbsp; nbsp;
          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日期记事功能的全部内容,希望大家会喜欢。

    您可能感兴趣的文章:
    • 基于Asp.net与Javascript控制的日期控件
    • ASP.NET中TextBox使用Ajax控件显示日期不全的问题解决方法
    • ASP.NET Calendar日历(日期)控件使用方法
    • ASP.NET项目开发中日期控件DatePicker如何使用
    • ASP.NET使用My97DatePicker日期控件实例
    上一篇:ASP.NET使用My97DatePicker日期控件实例
    下一篇:在ASP.NET 2.0中操作数据之二:创建一个业务逻辑层
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信