dataGridView控件DateTime列插入DateTimePicker

原创 2007年09月15日 11:37:00
 public Form1()
        
...{
            InitializeComponent();
        }


        
//定义一个DateTimePicker控件
        private DateTimePicker dTimePicker = new DateTimePicker();

        
//定义一个DataSet
        private DataSet ds;
       
        
private void Form1_Load(object sender, EventArgs e)
        
...
            
//隐藏dTimePicker
            dTimePicker.Visible = false;
            
            
//dataGirdView1控件数据绑定
            Data_Bind();


            
//定义控件dTimePicker当Text变更时委托于事件dTimePicker_TextChanged
            dTimePicker.TextChanged += new EventHandler(dTimePicker_TextChanged);

            
//dataGridView1添加控件dTimePicker
            dataGridView1.Controls.Add(dTimePicker);
        }


        
/**//// <summary>
        
/// dataGirdView绑定数据
        
/// </summary>

        private void Data_Bind()
        
...{
            
string sqlstr = "select businessname,lastlogindate from business";
            ds 
= SqlHelper.ExecuteDS(CommandType.Text, sqlstr);
            dataGridView1.DataSource 
= ds.Tables[0].DefaultView;
        }



        
//事件dTimePicker_TextChanged,当dTimePicker当Text变更时触发
        private void dTimePicker_TextChanged(object sender, EventArgs e)
        
...{
            
//把dTimePicker的Text值赋给dataGridView1选中的单元格值
            dataGridView1.CurrentCell.Value = dTimePicker.Text;
        }

        
        
private void dataGridView1_Scroll(object sender, ScrollEventArgs e)
        
...{
            
//当dataGridView1滚动条移动时dTimePicker控件隐藏
            dTimePicker.Visible = false;
        }


        
private void dataGridView1_ColumnWidthChanged(object sender, DataGridViewColumnEventArgs e)
        
...{
            
//当dataGridView1的列宽改变时dTimePicker控件隐藏
            dTimePicker.Visible = false;

        }


        
private void dataGridView1_CellClick(object sender, DataGridViewCellEventArgs e)
        
...{
            
//判断选中行时日期类型
            
//dt = ds.Tables[0];
            Type t = ds.Tables[0].Columns[dataGridView1.CurrentCell.ColumnIndex].DataType;
            DateTime d 
= DateTime.Now;
            
if (t== d.GetType() )
            
...{
                
//获得dataGridView1选中单元格显示区域的矩形
                Rectangle Rect = this.dataGridView1.GetCellDisplayRectangle(this.dataGridView1.CurrentCell.ColumnIndex, this.dataGridView1.CurrentCell.RowIndex, false);
                
//显示dTimePicker在dataGridView1选中单元格显示区域的矩形里面,即选中单元格内
                dTimePicker.Visible = true;
                dTimePicker.Top 
= Rect.Top;
                dTimePicker.Left 
= Rect.Left;
                dTimePicker.Height 
= Rect.Height;
                dTimePicker.Width 
= Rect.Width;
                
//dTimePicker控件获取初始值为dataGridView1选中单元格值
                dTimePicker.Text=dataGridView1.CurrentCell.Value.ToString();

            }

        }


        
~Form1()
        
...{
            ds.Dispose(); 
            ds.Clear();
            System.GC.Collect();
        }



    }

 

为DataGridView增加日期/时间列

为DataGridView增加日期/时间列,设计DataGridView时,在Edit Columns窗口中可以选择ColumnType为新增加的列类型CalendarColumn,设置ShowUpD...
  • kevingao
  • kevingao
  • 2006年09月02日 11:03
  • 5723

C#:DataGridView中列类型使用时间控件和下拉列表的自动匹配

1. DataGridView中使用时间控件作为列类型 DataGridView中默认不提供DateTimePicker类型的列类型,因此可以通过控件的覆盖模拟所需的功能。详细步骤如下: 第一步,...
  • kingzone_2008
  • kingzone_2008
  • 2013年01月05日 23:10
  • 6232

C#中DataGridView控件DateTime列插入DateTimePicker

  • 2011年10月18日 11:19
  • 81KB
  • 下载

C# 为DataGridView的一个列加入DateTimePicker控件

由于DataGridView自带的ColumnType里面没有DateTimePicker这个控件。所以要实现一个输入日期的列就比较麻烦了。通过以下方法可以往DataGridView加入DateTim...
  • diyoosjtu
  • diyoosjtu
  • 2012年05月20日 15:15
  • 6278

为DataGridView的一个列加入DateTimePicker控件(转)

由于DataGridView自带的ColumnType里面没有DateTimePicker这个控件。所以要实现一个输入日期的列就比较麻烦了。通过以下方法可以往DataGridView加入DateTim...
  • alisa525
  • alisa525
  • 2012年03月26日 16:08
  • 1426

datagridview中使用combobox下拉列表框,datetimepicker 日期选择框

  • 2008年12月13日 21:59
  • 37KB
  • 下载

C#:DataGridView中列类型使用时间控件和下拉列表的自动匹配

1. DataGridView中使用时间控件作为列类型 DataGridView中默认不提供DateTimePicker类型的列类型,因此可以通过控件的覆盖模拟所需的功能。详细步骤如下: 第一步,...
  • kingzone_2008
  • kingzone_2008
  • 2013年01月05日 23:10
  • 6232

C# DataGridView控件动态添加新行

DataGridView控件在实际应用中非常实用,特别需要表格显示数据时。可以静态绑定数据源,这样就自动为DataGridView控件添加相应的行。假如需要动态为DataGridView控件添加新行,...
  • angel20082008
  • angel20082008
  • 2016年06月20日 09:29
  • 4683

DataGridView控件用法(二):为每行记录最后加“编辑”-“删除”按钮列

1. 在DataGridView控件用法(一)中已经显示出列表数据,这时我们需要对每行数据记录进行编辑,需要添加“编辑”、“删除”、“查看”这样的超链接。代码如下: view sou...
  • SunCherryDream
  • SunCherryDream
  • 2015年06月06日 12:40
  • 4462

dataGridView控件DateTime列插入DateTimePicker

//定义一个DateTimePicker控件         private DateTimePicker dTimePicker = new DateTimePicker();       ...
  • eagle_610
  • eagle_610
  • 2012年03月16日 11:32
  • 359
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:dataGridView控件DateTime列插入DateTimePicker
举报原因:
原因补充:

(最多只允许输入30个字)